FOR /F 这是在批处理文件中跳过一行的正确方法

Posted

技术标签:

【中文标题】FOR /F 这是在批处理文件中跳过一行的正确方法【英文标题】:FOR /F is this the correct method for skipping a line in a batch file 【发布时间】:2021-06-09 10:22:54 【问题描述】:

我正在尝试查找并使用特定单词作为变量,以使用批处理脚本打印到 txt 文件中。

所以这是文本的一个例子。

10-03-2021 18:46:12:77 INFO: [SET_APP_VARS] Country:UK
10-03-2021 18:46:12:78 INFO: [SET_APP_VARS] Langauge:ENGLISH
10-03-2021 18:46:12:78 INFO: [SET_APP_VARS] Type:CLASSIC
10-03-2021 18:46:12:78 INFO: [SET_APP_VARS] Lane:801

所以我需要找到CLASSIC这个词并将其用作变量

下面的代码是否正确。

FOR /F "skip=2 tokens=1,2,3,4,5,6 delims=:" %%a IN (test.txt) do echo  Country is "%%f" & goto next

:next

FOR /F "skip=4 tokens=1,2,3,4,5,6 delims=:" %%a IN (test.txt) do echo  Motherboard is is "%%f" & goto done

:done

【问题讨论】:

%SystemRoot%\System32\find.exe "CLASSIC" 0< test.txt 1>NUL && Set "Var=CLASSIC" 【参考方案1】:

过滤您的输入有助于:

for /f "tokens=6 delims=:" %%a in ('find " Country:" test.txt') do echo Country is %%a
for /f "tokens=6 delims=:" %%a in ('find " Type:" test.txt') do echo Type is %%a

或者如果您需要更多:

    for /f "tokens=8,9 delims=: " %%a in (test.txt) do echo %%a is %%b

或使用变量:

for /f "tokens=8,9 delims=: " %%a in (test.txt) do set "_%%a=%%b"
set _

或者只是一些(比第一个 sn-p 快得多,因为它只需读取一次 test.txt):

for /f "tokens=8,9 delims=: " %%a in ('findstr "Country: Type:" test.txt') do set "_%%a=%%b"
set _

【讨论】:

【参考方案2】:

根据我认为您可能正在做的事情,我可能会提供不同的方法:

@Echo Off
SetLocal EnableExtensions
For /F "UseBackQ Tokens=1,* Delims=]" %%G In ("test.txt") Do (
    For /F "Tokens=1,* Delims=: " %%I In ("%%H") Do Echo Set "%%I=%%J" 
)
If "%Type%" == "CLASSIC" …

只需根据需要将最后一行中的 替换为您预期的其余命令即可。

【讨论】:

【参考方案3】:

您好,感谢大家的输入,在我阅读这里的回复之前,我实际上想出了一些不同的东西,因为日志文件是用 UCS-2-LE 编码的,所以代码不会读取该文件,所以我将其更改为UTF 与下面的命令。

powershell -command "Get-Content C:\Install\Logs\*LOAD-BOOTS_ENVIRONMENT.log" > C:\Install\Logs\Boots_logfile.txt 

此外,日志文件以附加到文件名开头的日期/时间开头,例如 20210311215550LOAD-BOOTS_ENVIRONMENT,因此我将其转换为名称为 Boots_logfile.txt 的 UTF。

所以在这个文件中有一行文本,如下所示(行号并不总是相同)

11-03-2021 21:56:13:58 INFO: [SET_STORE_NUMBER] Name:Manchester
11-03-2021 21:57:02:71 INFO: [SET_APP_VARS] SET Country:UK
11-03-2021 21:57:02:74 INFO: [SET_APP_VARS] SET Language:ENGLISH
11-03-2021 21:57:02:81 INFO: [SET_APP_VARS] Key:STORENUMBER Value:120
11-03-2021 21:57:02:89 INFO: [SET_APP_VARS] Key:IPADDRESS Value:10.10.10.10

所以我写了下面的代码来找到商店名称曼彻斯特

set torun=findstr /c:"[SET_STORE_NUMBER] Name" "C:\Install\Logs\Boots_logfile.txt" 
for /f "tokens=1,2,3,4,5,6 delims=:" %%a in ('%torun%') do set boots001="%%f"

并使用echo Store Name%TAB%%TAB%%boots001%显示它

这看起来是正确的还是有更短的方法,所以如上所述,我会使用%boots002% %boots003% 等获取商店名称、数字 IP 地址等

【讨论】:

以上是关于FOR /F 这是在批处理文件中跳过一行的正确方法的主要内容,如果未能解决你的问题,请参考以下文章

在CSV文件中跳过标题

在 Fortran90 中从文本文件中跳过一行

使用 CSV 文件在循环中跳过第一行(字段)? [复制]

在 Yii2 中跳过 CSV 文件的第一行

如何在 C++ 中跳过空格

在播放中跳过静音 - 优化值