从文本脚本

时间:2016-06-07 15:23:16

标签: batch-file set extract

我正在尝试让脚本一次性从多个文本文件中提取特定行。我有脚本将从文本中提取行,但我不能让它对多个文件执行此操作。

我所拥有的是我工厂中每台计算机的库存文件。我尝试提取具有用户名称的16,因此每个文件在第16行都有不同的值,但它总是在第16行。

示例文件我尝试从中提取:

<HTML>
<BODY>
<center>
<table border=1>
<tr>
    <th>Full Name</th>
    <th>UserID</th>
    <th>IP Address</th>
    <th>Make</th>
    <th>Model</th>
    <th>Serial Number</th>
    <th>Default Printer</th>
</tr>
<tr>
<td>John Doe</td>
<td>USERNAME</td>
<td> 1. 1. 1.1
</td>
<td>Hewlett-Packard
</td>
<td>HP Compaq 8000 Elite SFF PC
</td>
<td>SERIALNUMBERX
</td>
<td>Microsoft XPS Document Writer
</td>
</tr>
</table></font>
<br />
Inventory taken on 2015/11/24 at 07:43:14. </center>
</BODY>
</HTML>

我希望脚本将信息提取到文本文件中,这样我就可以将其放入电子表格中了。

到目前为止,这是我的剧本。 (我认为是toop部分是问题 - 具体是FOR命令。抱歉我的脚本无知。我试着去学习。

@echo off &setlocal
setlocal EnableDelayedExpansion
set filename=\\computername\c$\users\username\desktop\pcs.txt
for /F "tokens=*" %%a in ('type %filename%') do (
set file=%%a.html
)
set /a from=16
set /a till=16

for /f %%i in ('type "%file"^|find /v /c ""') do if %till% gtr %%i set /a till=%%i
set /a skip=from-1

setlocal EnableDelayedExpansion
<"!file!" (
for /l %%i in (1 1 %skip%) do set /p "="
for /l %%i in (%from% 1 %till%) do (
set "ln="
set /p "ln="
echo(!ln! >> c:\users\username\desktop\extracted.txt
 )
)
endlocal
pause

我的pcs.txt文件设置如下:

pc1
pc2
pc3

2 个答案:

答案 0 :(得分:0)

总是第16行?

@echo off
setlocal 
set count=0
for %%a in (*.txt) do call :getname %%a
set name
goto :eof

:getname
set /a count+=1
for /f "tokens=2 delims=<>" %%i in ('more +15 %1') do (set "name%count%=%%i" & goto :eof)

答案 1 :(得分:0)

我最终使用psexec在每台计算机上运行该文件。

@echo off &setlocal
setlocal EnableDelayedExpansion
set "file=\\server\public\is\kixtartlogs\%computername%.html"
set /a from=16
set /a till=16

for /f %%i in ('type "%file%"^|find /v /c ""') do if %till% gtr %%i set /a till=%%i
set /a skip=from-1

setlocal EnableDelayedExpansion
<"!file!" (
for /l %%i in (1 1 %skip%) do set /p "="
for /l %%i in (%from% 1 %till%) do (
set "ln="
set /p "ln="
echo(%computername% !ln! >> \\computername\c$\users\username\desktop\extracted.txt
)
)
endlocal

PSEXEC命令: psexec @\\server\c$\pcs.txt -u domain\username -p password cmd /c \\server\c$\extract.bat