标题: [文本处理] [已解决]批处理如何提取特定符号之前全是数字的行? [打印本页]
作者: 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
- @echo off
- for /f "delims=# tokens=1*" %%a in (a.txt) do echo %%a|findstr "^[0-9]*$"&&echo %%a#%%b >>new.txt
-
- 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效率不高,是你的写法效率不高。- findstr "^[0-9]*#" a.txt >b.txt
复制代码
作者: yangfengoo 时间: 2012-5-10 13:23
回复 10# gawk
呵呵,确实。一时没转过弯来。后面的代码受前面的思路影响了。
欢迎光临 批处理之家 (http://bbs.bathome.net/) |
Powered by Discuz! 7.2 |