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

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

废话不多说上例子:

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键。。

感谢。
1

评分人数

    • Batcher: 感谢给帖子标题标注[已解决]字样PB + 2

  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
复制代码

TOP

回复 2# yangfengoo


    正在运行,好慢。。。

TOP

回复 2# yangfengoo


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

失败了。多出来了好多个文档。

TOP

你的文本很大?findstr效率不是很高
如果用第三方gawk 或sed应该会快些

TOP

回复 5# yangfengoo


    文本不大1M多。

TOP

@echo off

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

pause
试试这个。你给的样本测试你没问题,如果不行请提供原件参考
1

评分人数

TOP

回复 7# yangfengoo


    在运行了。稍等

TOP

回复 8# yx74110


    OK.搞定.感谢.

TOP

回复 5# yangfengoo


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

TOP

回复 10# gawk


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

TOP

返回列表