标题: [求助]如何处理空值
[打印本页]
作者: hgx126
时间: 2009-2-9 21:32
标题: [求助]如何处理空值
a.txt内容如下:
1|安波|5411|二元街|正常
2|安阳|5411||正常
3|安顺|5411|寿山寺街|正常
注意第二行的“5411”与“正常”之间有一个空值。
要将5411替换成“营业部”,写如下代码:
for /f "delims=| tokens=1-5" %%a in (a.txt) do (
setlocal enabledelayedexpansion
set var=%%c
set var=!var:5411=营业部!
echo %%a^|%%b^|!var!^|%%d^|%%e>>"b.txt"
endlocal
)
处理后b.txt如下:
1|安波|营业部|二元街|正常
2|安阳|营业部|正常|
3|安顺|营业部|寿山寺街|正常
空值所占位置不见了。如何让b.txt第二行“营业部”与“正常”之间继续保持一个空值?
即将第二行成为:
2|安阳|营业部||正常
???
Last edited by hgx126 on 2009-2-9 at 21:34 ]
作者: netbenton
时间: 2009-2-9 21:42
for /f "delims=" %%a in (a.txt) do (
setlocal enabledelayedexpansion
set var=%%a
set var=!var:5411=营业部!
echo !var!>"b.txt"
endlocal
)
Last edited by netbenton on 2009-2-9 at 21:43 ]
作者: hgx126
时间: 2009-2-9 21:59
netbenton的办法对目前a.txt中的内容能用。
但是,不好意思,我没有把a.txt内容展示完,只是摘录了一部份。
我的原文还好多列,且全部是数字,也有可能含有“5411”。所以必须用“|”分隔后,用“营业部”替换第3列中的5411,而其它列中的“5411”不替换成“营业部”。
还请帮忙。
作者: ficn
时间: 2009-2-9 22:22
是不是这样
@echo off&setlocal ENABLEDELAYEDEXPANSION
for /f "tokens=1-3* delims=|" %%a in (a.txt) do (set q=%%c
echo %%a^|%%b^|!q:5411=营业部!^|%%d)
pause
Last edited by ficn on 2009-2-9 at 23:01 ]
作者: netbenton
时间: 2009-2-9 22:28
@echo off
for /f "delims=" %%a in (zz.txt) do (
set "var=%%a"
setlocal enabledelayedexpansion
set "var=!var:|5411|=|营业部|!"
echo.!var!
endlocal
)
pause
作者: hgx126
时间: 2009-2-9 23:22
个人觉得ficn的思路正适合我的想法。谢谢