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