返回列表 发帖

[文本处理] BAT批处理如何读取txt中包含指定字符串的行?

需求
文本格式:
如:
2014-05-13 00:00:00,003 INFO  
2014-05-13 00:00:00,019 INFO
sdsaldsdlfkjld
2014-05-13 00:01:25,145 ERROR
2014-05-13 00:03:00,037 INFO
sdsaldsdlfkjld
2014-05-13 00:03:00,037 ERROR  
2014-05-13 00:05:37,695 INFO  
2014-05-13 00:10:10,339 INFO
sdsaldsdlfkjld
test
1COPY
需要显示的结果:
sdsaldsdlfkjld
2014-05-13 00:01:25,145 ERROR
sdsaldsdlfkjld
2014-05-13 00:03:00,037 ERROR  
sdsaldsdlfkjld
test
1
COPY
需求:
1.每行以时间开始的并且还很ERROR字符 则输出到新文件
2.每行不是时间开始的直接输出到新文件
注意:非时间开始的行可能有特殊字符如:<a></a>
--------------------------------------------------------------------------------
我写了一个,单个运行可以一起就有问题
@echo off & setlocal EnableDelayedExpansion
for /f "delims=""" %%i in (QQ.txt) do (
   set "str=%%i"
    echo !str!  |findstr "^[0-9][0-9][0-9][0-9] ERROR ">>1.txt
    echo !str!  |findstr  /V  "^[0-9][0-9][0-9][0-9]">>1.txt
)
pauseCOPY

坐等大神们回复·~~

TOP

开文件,遍历每一行,只要行 结尾含有info就丢弃,否则就输出到另外一个文件。 ----这样?
脚本是写给人看的,是写给用户看的,而不是写给机子看的
用户能看懂、会修改的脚本,才是好脚本。
写易懂的powershell脚本帮人解决问题,进而让用户学会自渔,吾所愿也

TOP

[quote]坐等大神们回复·~~

TOP

回复 3# PowerShell
还会有其他字符  不能按info处理

TOP

@echo off
setlocal EnableDelayedExpansion
(for /f "delims=" %%i in (1.txt) do (
    set "str=%%i"
    echo !str! | findstr "^....-..-...*ERROR" > nul
    if !errorlevel! equ 0 (
        echo %%i
    ) else (
        echo !str! | findstr "^....-..-.." > nul
        if !errorlevel! neq 0 (
            echo %%i
        )
    )
))>2.txtCOPY

TOP

@echo off
findstr "^[1-9][0-9][0-9][0-9]-.*" 1.txt|findstr /iv "error">$
findstr /ivxg:$ 1.txt>2.txt
del $
pauseCOPY

TOP

回复 6# DAIC

按上面代码可以,但上面说了txt里可能含有<a>0215138009</a>

所以运行bat会有三种错误
1.此时不应有 <。
2.命令语法不正确。
3.系统找不到指定的文件。

----怎么让他忽略txt里的特殊字符????

TOP

回复 8# poi
@echo off
setlocal EnableDelayedExpansion
(for /f "delims=" %%i in (1.txt) do (
    set "str=%%i"
    echo "!str!" | findstr "^.....-..-...*ERROR" > nul
    if !errorlevel! equ 0 (
        echo !str!
    ) else (
        echo "!str!" | findstr "^.....-..-.." > nul
        if !errorlevel! neq 0 (
            echo !str!
        )
    )
))>2.txtCOPY

TOP

你好,刚那个bat还有点小问题,能看下嘛?

不用发短消息给我,直接在我的回帖下面点击“回复”就行了。

TOP

回复 10# DAIC
嗯  谢谢~
没问题了,还有就是问下bat处理txt一般能处理多大·~,几十M应该没问题·~
我刚试了下10m 运行了好久  等会我算下时间

TOP

@echo off
for /f "tokens=1-3" %%a in (QQ.txt) do (
    if not "%%c"=="INFO" (echo %%a %%b %%c>>2.txt)
)

TOP

回复 11# poi


用gawk.exe试试
gawk "{if($0~/....-..-...*ERROR/)print;else if($0!~/....-..-../)print}" 1.txt > 2.txtCOPY

TOP

回复 10# DAIC
有的行太长报错怎么办?
报:findstr:行1太长。

TOP

本帖最后由 poi 于 2014-5-15 17:09 编辑

还有我的文本一般在10-30m
有的行可能也很多~~
有什么好的方法没(效率能提高的)???

我们现在使用html 用js提取这些信息,也要分割文件~~
如果bat也要分割就没多大意义了·~

TOP

返回列表