Board logo

标题: [文本处理] [已解决]批处理如何提取特定符号之前全是数字的行? [打印本页]

作者: yx74110    时间: 2012-5-10 10:18     标题: [已解决]批处理如何提取特定符号之前全是数字的行?

废话不多说上例子:

43214132#321321            32132143214
afdafadsfds#fasdfsad        fdasfdasfadsf
2ws21wsw1#fdsfdsafd      dsaDASdsaDAS
FDSAFDSFFD#FDFDDFD     232432ESADA
8765765765#DSDSFDD    FDSFDASFDSAFA
434352345#35245432     FDSAFDSAFDSA342E


处理结果为:
43214132#321321            32132143214
8765765765#DSDSFDD    FDSFDASFDSAFA
434352345#35245432     FDSAFDSAFDSA342E


也就是保留每行#号之前全是数字的行

中间空白出是文本中的TAB键。。

感谢。
作者: yangfengoo    时间: 2012-5-10 10:36

  1. @echo off
  2. for /f "delims=# tokens=1*" %%a in (a.txt) do echo %%a|findstr "^[0-9]*$"&&echo %%a#%%b >>new.txt
  3. pause
复制代码

作者: yx74110    时间: 2012-5-10 10:40

回复 2# yangfengoo


    正在运行,好慢。。。
作者: yx74110    时间: 2012-5-10 10:43

回复 2# yangfengoo


    '縌埘じ貞£@lishumin' 不是内部或外部命令,也不是可运行的程序
或批处理文件。
系统找不到指定的文件。
系统找不到指定的文件。

失败了。多出来了好多个文档。
作者: yangfengoo    时间: 2012-5-10 10:44

你的文本很大?findstr效率不是很高
如果用第三方gawk 或sed应该会快些
作者: yx74110    时间: 2012-5-10 10:45

回复 5# yangfengoo


    文本不大1M多。
作者: yangfengoo    时间: 2012-5-10 10:54

@echo off

>new.txt (for /f "tokens=*" %%a in (a.txt) do echo %%a|findstr "^[0-9]*#")

pause
试试这个。你给的样本测试你没问题,如果不行请提供原件参考
作者: yx74110    时间: 2012-5-10 10:56

回复 7# yangfengoo


    在运行了。稍等
作者: yx74110    时间: 2012-5-10 11:02

回复 8# yx74110


    OK.搞定.感谢.
作者: gawk    时间: 2012-5-10 13:12

回复 5# yangfengoo


不是findstr效率不高,是你的写法效率不高。
  1. findstr "^[0-9]*#" a.txt >b.txt
复制代码

作者: yangfengoo    时间: 2012-5-10 13:23

回复 10# gawk


    呵呵,确实。一时没转过弯来。后面的代码受前面的思路影响了。




欢迎光临 批处理之家 (http://bbs.bathome.net/) Powered by Discuz! 7.2