标题: [文本处理] 批处理如何查找文本里指定字符☆后的3个字符并在相同的3个字符前加指定字符☆。 [打印本页]
作者: a000000_82 时间: 2013-12-23 20:22 标题: 批处理如何查找文本里指定字符☆后的3个字符并在相同的3个字符前加指定字符☆。
本帖最后由 pcl_test 于 2017-6-18 22:00 编辑
例如:001.txt内容如下:
0001:xx,xx,29,xx,xx,xx,xx,xx,
0002:xx,xx,xx,xx,xx,29,xx,xx,
略~~~
3478:xx,xx,xx,xx,xx,☆29,
3479:xx,xx,xx,xx,29,xx,xx,xx,
002.txt内容如下:
0001:xx,xx,10,xx,xx,xx,xx,xx,
0002:xx,xx,xx,xx,xx,☆10,xx,xx,
略~~~
3478:xx,xx,xx,xx,xx,10,
3479:xx,xx,xx,xx,10,xx,xx,xx,
处理后效果为:
001.txt
0001:xx,xx,☆29,xx,xx,xx,xx,xx,
0002:xx,xx,xx,xx,xx,☆29,xx,xx,
略~~~
3478:xx,xx,xx,xx,xx,☆29,
3479:xx,xx,xx,xx,☆29,xx,xx,xx,
002.txt
0001:xx,xx,☆10,xx,xx,xx,xx,xx,
0002:xx,xx,xx,xx,xx,☆10,xx,xx,
略~~~
3478:xx,xx,xx,xx,xx,☆10,
3479:xx,xx,xx,xx,☆10,xx,xx,xx,
注:,号作用为区分序号相同字节。
希望各位大大帮帮忙!!在此先谢谢大家~~~。
作者: DAIC 时间: 2013-12-23 21:56
- @echo off
- for /f "delims=" %%a in ('dir /b *.txt') do (
- for /f "delims=" %%i in ('sed -r "/☆/!d; s/.*[,:]☆([^,:]+),.*/\1/" %%a') do (
- set "strRep=%%i"
- )
- sed -r "s/([,:])(%strRep%,)/\1☆\2/g" %%a > %%a_new
- move /y %%a_new %%a
- )
复制代码
作者: a000000_82 时间: 2013-12-24 17:51
请问下能否帮忙调整下不用"strRep"。
欢迎光临 批处理之家 (http://www.bathome.net/) |
Powered by Discuz! 7.2 |