找回密码
 注册
搜索
[新手上路]批处理新手入门导读[视频教程]批处理基础视频教程[视频教程]VBS基础视频教程[批处理精品]批处理版照片整理器
[批处理精品]纯批处理备份&还原驱动[批处理精品]CMD命令50条不能说的秘密[在线下载]第三方命令行工具[在线帮助]VBScript / JScript 在线参考
查看: 23146|回复: 3

[文本处理] 批处理命令FOR循环处理行数过多的文件为何出错?

[复制链接]
发表于 2013-11-30 05:51:35 | 显示全部楼层 |阅读模式
文件AAA.txt中的内容大致格式如下:
{ BBB1  CC1C  DDD1 } EEE1  FFF1  GGG1  ……
{ BBB2  CCC2  DDD2 } EEE2  FFF2  GGG2  ……
{ BBB3  CCC3  DDD3 } EEE3  FFF3  GGG3  ……
现在只需要符号“}”后面的内容,我的实现方式是FOR /F "tokens=1* delims=}" %%I IN (AAA.txt) DO ECHO %%J >> BBB.txt
生成的BBB.txt就是预期的结果。
问题来了:当AAA.txt中行数不多的时候,BBB.txt中的内容正确,一旦AAA.txt中行数过多,BBB.txt就不对了,这是怎么回事?请高手指点,谢谢!
发表于 2013-12-1 07:08:20 | 显示全部楼层
用Notepad++打開,發現有許多NUL,是這個原因嗎?
发表于 2013-12-1 16:04:46 | 显示全部楼层
如楼上所说,存在很多Nul,就是很多0D0A前面存在00
加个more或find
  1. (FOR /F "tokens=1*delims=}" %%I IN ('more A.txt') DO ECHO,%%J)>B.txt
复制代码
 楼主| 发表于 2013-12-1 21:48:25 | 显示全部楼层
回复 3# apang


问题解决了,谢谢!

另外向专家请教下:NUL是什么东西?我用UltraEdit打开没有看到这个(还是我软件没有设置好?)。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

Archiver|手机版|小黑屋|批处理之家 ( 渝ICP备10000708号 )

GMT+8, 2026-3-19 20:15 , Processed in 0.077345 second(s), 8 queries , File On.

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

快速回复 返回顶部 返回列表