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

[文本处理] 批处理如何查找文本里指定字符☆后的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,


注:,号作用为区分序号相同字节。


希望各位大大帮帮忙!!在此先谢谢大家~~~。

请问下能否帮忙调整下不用"strRep"。

TOP

  1. @echo off
  2. for /f "delims=" %%a in ('dir /b *.txt') do (
  3.     for /f "delims=" %%i in ('sed -r "/☆/!d; s/.*[,:]☆([^,:]+),.*/\1/" %%a') do (
  4.         set "strRep=%%i"
  5.     )
  6.     sed -r "s/([,:])(%strRep%,)/\1☆\2/g" %%a > %%a_new
  7.     move /y %%a_new %%a
  8. )
复制代码

TOP

返回列表