Board logo

标题: 查找替换文本,不使用外部命令 [打印本页]

作者: shixin333     时间: 2010-10-8 10:13    标题: 查找替换文本,不使用外部命令

文件1.csv

aa,bb,cc,dd,ee,ff
001,122,33,,12,65
002,111,33,,12,63
003,353,33,,12,69
...


想实现查找替换功能,凡是33,,12 替换为88,,38

[ Last edited by shixin333 on 2010-10-8 at 10:58 ]
作者: shixin333     时间: 2010-10-8 11:17
求高手相助
实现结果
『楼 主』:  查找替换文本,不使用外部命令

aa,bb,cc,dd,ee,ff
001,122,88,,38,65
002,111,88,,38,63
003,353,88,,38,69
作者: shixin333     时间: 2010-10-8 11:48
@echo off   
setlocal enabledelayedexpansion   
for /f "delims=" %%i in ('type 文件1.csv') do (   
    set str=%%i   
    set str=!str:33,,12=88,,38!   
    echo !str!>>tmp.txt   
)
copy /y tmp.txt 文件1.csv
echo 循环完成了

这段代码可以改成查找替换,可是我的CSV文件有很多,我不可以一个一个去输入文件名,我想自动完成,请高手指教
作者: shixin333     时间: 2010-10-8 12:07
自已弄了一个,求高手指教是否有问题


@echo off   
setlocal enabledelayedexpansion
del csv.tmp >nul 2>nul
::2>nul 是屏蔽出错显示 >nul 2>nul 是无论对错,都屏蔽屏幕显示

for %%a in (*.csv) do (   
for /f "delims=" %%i in ('type %%a') do (   
    set str=%%i   
    set str=!str:BVT8A,,EBYGA=KQFC01,,DH0HA!   
    echo !str!>>csv.tmp   
)
copy /y csv.tmp %%a >nul
del csv.tmp >nul 2>nul
)
echo 循环完成了