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

[文本处理] 各位大大,请问下批处理可以查找文本内容进行字符串替换吗?

[复制链接]
发表于 2022-9-20 20:52:47 | 显示全部楼层 |阅读模式
在一个C文本中,查找类似 lv_xxx_create(xxx, NULL)的函数(文本),然后替换成lv_xxx_create(xxx)这样的格式,有没有啥实现方法吗?
 楼主| 发表于 2022-9-20 20:54:44 | 显示全部楼层
回复 1# stone_bat

xxx代表任意长度字符
发表于 2022-9-20 21:42:12 | 显示全部楼层
回复 1# stone_bat


  不确定我理解的对不对。

假如有C语言文件:demo.c

  1.         print 1
  2.    lv_xxx_create(xxx, NULL) {
  3.         print 2
  4.    }
  5.    
  6.    print 3
  7.    lv_xxx_create(yyy, NULL) {
  8.         print 4
  9.    }
复制代码
我的脚本是:findstr-and-replace.bat
  1. @ECHO OFF
  2. if exist "%~1" SET "Ctxt=%~1"
  3. SET "Cnew=%~n1_new%~x1"
  4. setlocal enabledelayedexpansion
  5. CALL :Findstr_and_Trim >"%Cnew%"
  6. ECHO.已生成新的文件:"%Cnew%"
  7. pause
  8. exit /B

  9. :Findstr_and_Trim
  10. FOR /F "usebackq delims=" %%a in ("%Ctxt%") do (
  11.         ECHO.%%a | findstr /R /C:"lv_.*_create(.*, NULL" >nul 2>nul && (
  12.                 FOR /F "tokens=2,4 delims=_(," %%b in ("%%a") do if "%%b"=="%%c" (
  13.                         CALL :TrimPrint "%%a" ", NULL"
  14.                 ) else ( ECHO.%%a)
  15.         ) || ECHO.%%a
  16. )
  17. GOTO:EOF

  18. :TrimPrint <原文本> <去掉文本>
  19. SET string=%~1
  20. SET string=!string:%~2=!
  21. ECHO.%string%
  22. GOTO:EOF
复制代码
然后将demo.c拖放到findstr-and-replace.bat文件上,或在命令行启动findstr-and-replace.bat,将demo.c文件路径作为第1参数传入 findstr-and-replace.bat,得到结果文件格式如下:demo_new.c
  1.         print 1
  2.    lv_xxx_create(xxx) {
  3.         print 2
  4.    }
  5.    
  6.    print 3
  7.    lv_xxx_create(yyy, NULL) {
  8.         print 4
  9.    }
复制代码
发表于 2022-9-21 11:25:03 | 显示全部楼层
回复 1# stone_bat


考虑到c文件可能包含很多特殊字符,建议使用:
http://bcn.bathome.net/s/tool/index.html?key=sed
  1. sed "s/\(lv_.*_create(.*\), NULL)/\1)/" 1.c > 2.c
复制代码
 楼主| 发表于 2022-9-21 14:16:05 | 显示全部楼层
回复 3# Echo11


    好的,谢谢大佬
 楼主| 发表于 2022-9-21 14:16:18 | 显示全部楼层
回复 4# Batcher


    谢谢,我去试试
您需要登录后才可以回帖 登录 | 注册

本版积分规则

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

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

Powered by Discuz! X3.5

© 2001-2026 Discuz! Team.

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