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

[文本处理] 批处理怎么在文本文档中隔行后面加入同样内容?

比如:
11111111
22222222
33333333
44444444
55555555
66666666
77777777

改成这样

11111111--你好
22222222
33333333--你好
44444444
55555555--你好
66666666
77777777--你好

隔2行怎么写?隔3行怎么写?
刚接触批处理,谢谢了

本帖最后由 cb02356828 于 2012-6-16 15:27 编辑

刚才的测试了一下,错误很多,待会儿再贴上来

TOP

cb02356828 你好,
我试了不行呀

TOP

回复 3# yyyyyzzz
现在可以了:
  1. @echo off&setlocal enabledelayedexpansion
  2. set/a b=1
  3. for /f %%i in (原文件.txt) do (
  4.   rem 下面这句的2意思是隔1行,隔2行就改成3,隔3行就改成4
  5.   set/a c=!b!%%2
  6.   set s=%%i
  7.   if !c! equ 0 ( set s=%%i -- 你好 )
  8.   echo !s! >>新文件.txt
  9.   set/a b=!b!+1
  10. )
  11. pause>nul
复制代码

TOP

能用了,太谢谢了,

TOP

回复 4# cb02356828
基本功能是实现了,接下来可以考虑如何规避特殊符号的影响以及如何保留空行和分号开头的行。
看得多说得多,远比不上写得多。

TOP

另两解:
  1. @echo off
  2. for /f "delims="eol^= %%a in (a.txt) do (
  3.    set /a n=!n,n/n && echo %%a|| echo %%a--你好
  4. ) 2>nul
  5. rem 通过非零运算达到区别隔行效果,当 n 为 1,时非零运算结果为 0,导致 n/n 是非法运算,于是可以通过 set /a 的运行成败来区分输出
复制代码
  1. @echo off
  2. (for /f "delims=" %%a in ('findstr /n .* a.txt') do (
  3.    setlocal enabledelayedexpansion
  4.    set /p a=
  5.    set /p b=
  6.    echo !a!--你好
  7.    echo !b!
  8.    endlocal
  9. ))<a.txt
  10. rem 用 set /p 分行获取文本内容,以便区分输出,不过要清空变量 a 和 b 的内容以防遇到空行,若无空行可以将 ('findstr /n .* a.txt') 改为 (a.txt)
复制代码

TOP

  1. gawk "NR%2{$0=$0\"--你好\"}1" a.txt >b.txt
复制代码

TOP

返回列表