[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
返回列表 发帖

[文本处理] 批处理如何提取每行中数字大于300的行?

2017/7/21 12:29:09        来自 202.102.227.1 的回复: 字节=32 时间=347ms TTL=250
2017/7/21 12:29:10        来自 202.102.227.1 的回复: 字节=32 时间=335ms TTL=250
2017/7/21 12:29:11        来自 202.102.227.1 的回复: 字节=32 时间=323ms TTL=250
2017/7/21 12:29:12        来自 202.102.227.1 的回复: 字节=32 时间=2ms TTL=250
2017/7/21 12:29:13        来自 202.102.227.1 的回复: 字节=32 时间=2ms TTL=250
2017/7/21 12:29:14        来自 202.102.227.1 的回复: 字节=32 时间=2ms TTL=250

上面的文本中,怎么把时间大于等于300ms的这一行提取出来?

@echo off
findstr /r "[3-9][0-9][0-9]ms" "D:\1.txt"
pause

TOP

回复 2# wang6542975

/r是多余的,另外大于999的某些数也匹配不到,虽然很可能不会出现那么大的数

TOP

  1. //&@cls&cscript -nologo -e:jscript "%~f0" >保存.TXT&pause
  2. WSH.Echo(
  3.     new ActiveXObject('Scripting.FileSystemObject').OpenTextFile('测试文本.txt', 1).ReadAll().replace(/.+时间=[1-2]?[0-9]?[0-9]ms.+[\r\n]*/g, '')
  4. )
复制代码
根据论坛的相关文章修改的,好像不怎么严谨匹配

TOP

一个比较邪道的做法...用UltraEdit处理下文字之间的空行,变成tab空行,贴到excel 然后排列就OK了

TOP

回复 5# WindCat


不需要UE
Excel导入数据的时候可以自己指定列分隔符或者字符串宽度
环境所限,需要使用 PowerShell 2.0 版本。

TOP

返回列表