gpt4 book ai didi

csv - 使用批处理程序省略 .LOG 文件中的前 5 行

转载 作者:行者123 更新时间:2023-12-05 01:34:44 26 4
gpt4 key购买 nike

我创建了一个 .bat 文件,它捕获其目录中的所有 .log 文件并将它们全部编译成一个 .csv 文件。我希望它在编译时省略而不是删除每个文件的前 5 行,从而保留原始文件并在生成的 .csv 文件中保留这些行。

PLEASE NOTE: I am simply using the .csv file to hold the compiled .log files. I know that the intended result bears no resemblance to an actual .csv file, I will process the file in excel to seperate the values.

.LOG 文件('表示要删除的行 - 实际上不存在于文件中的这些行中):

'20160201
'Time Side Serial # Active Current Idle Current OK/NOK
'----------- -------- --------------- ------------------- -------------- ---
'
'
00:00:23 Left 4EEFD9 6.59418mA 0.00003mA OK
00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK

.CSV 输出文件:

00:00:23    Left     4EEFD9     6.59418mA           0.00003mA      OK     
00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK
00:00:44 Left 4EEFDC 6.32207mA 0.00004mA OK
00:00:44 Right 4EEF77 6.66909mA 0.00006mA OK
00:01:00 Left 4EEFB1 6.31158mA 0.00001mA OK
00:01:00 Right 4EEFA5 6.54818mA 0.00003mA OK
00:01:17 Left 4EEFA9 6.52762mA 0.00006mA OK

这是我使用的代码:

rem Script to process .log files to remove first five lines.
for %%I in (*.log) do for /f "delims=, tokens=* skip=5" %%x in (%%I) do echo %%x >> "%%I.new"

rem Script to compile .log files into .csv file.
for %%f in (*.log.new) do CALL :label "%%f" "results.csv"

:label

set resultfile=%2
type %1 >> %resultfile%
echo ; >> %resultfile%

exit/b

它设法按照我想要的方式处理 .log 文件,但这需要很长时间才能完成,因为每个文件包含将近 10,000 行,并且批处理器将每一行复制到新文件中。有没有更好的方法让它忽略前 5 行?


编辑 1:

合并 Aacini 提供的原始批处理脚本可提供以下结果:

C:\Users\...\Desktop>set /P "=" 

C:\Users\...\Desktop>set /P "="

C:\Users\...\Desktop>set /P "="

C:\Users\...\Desktop>set /P "="

C:\Users\...\Desktop>set /P "="
00:00:23 Left 4EEFD9 6.59418mA 0.00003mA OK
00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK
00:00:44 Left 4EEFDC 6.32207mA 0.00004mA OK
00:00:44 Right 4EEF77 6.66909mA 0.00006mA OK
...

注意:处理器不能再运行多个 .log 文件。它在第一个文件之后停止执行。此时我必须运行两个 .bat 文件。第一个使用 Aacini 的代码(参见他的回答),然后是这个,因为我无法将两者结合起来:

rem Script to compile .log files into .csv file.
for %%f in (*.log) do CALL :label "%%f" "results.csv"

:label

set resultfile=%2
type %1 >> %resultfile%
echo ; >> %resultfile%

exit/b

使用 Aacini 的更新代码,我得到了与原始代码相同的结果并且速度更快,但是它仍然在第一个 .log 文件之后停止,并且 .csv 文件的最后一行现在显示以下内容:Terminate batch工作(是/否)?


编辑 2:

使用 dbenham 的第一个代码解决方案,我得到了与原始代码相同的结果。然而,第二个代码给出了这个结果:

C:\Users\...\Desktop>(
for /F "skip=5 usebackq delims=" %L in ("20160201.log") do echo(%L
echo ;
)

C:\Users\...\Desktop>echo(00:00:23 Left 4EEFD9 6.59418mA 0.00003mA OK
00:00:23 Left 4EEFD9 6.59418mA 0.00003mA OK

C:\Users\...\Desktop>echo(00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK
00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK

C:\Users\...\Desktop>echo(00:00:44 Left 4EEFDC 6.32207mA 0.00004mA OK
00:00:44 Left 4EEFDC 6.32207mA 0.00004mA OK

第三个代码给出了这个结果:

C:\Users\...\Desktop>(
more +5 "20160201.log"
echo ;
)
00:00:23 Left 4EEFD9 6.59418mA 0.00003mA OK
00:00:23 Right 4EEFEF 6.85377mA 0.00001mA OK
00:00:44 Left 4EEFDC 6.32207mA 0.00004mA OK
00:00:44 Right 4EEF77 6.66909mA 0.00006mA OK

编辑 3:

我错过了 @echo off。 dbenham 更新后的第 3 个脚本可以解决问题。

最佳答案

我认为这是“将 *.log 文件中除前 5 行之外的所有行复制到 *.log.new 文件中”的最快方法:

for %%I in (*.log) do (

rem Read from this file
< "%%I" (

rem Omit the first 5 lines
for /L %%a in (1,1,5) do set /P "="

rem Copy the rest
findstr "^"

rem And create the new file
) > "%%I.new"

)

也许如果您向我们展示最终 .csv 输出文件的格式,我们也可以帮助您以更快的方式创建它...

编辑:我猜下面的代码生成了 OP 所需的 results.csv 输出文件:

@echo off

(for %%I in (*.log) do (

rem Read from this file
< "%%I" (

rem Omit the first 5 lines
for /L %%a in (1,1,5) do set /P "="

rem Copy the rest
findstr "^"

)

echo ;

)) > results.csv

关于csv - 使用批处理程序省略 .LOG 文件中的前 5 行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35459145/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com