Board logo

标题: [求助]如何处理空值 [打印本页]

作者: 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的思路正适合我的想法。谢谢