中国DOS联盟论坛

中国DOS联盟

-- 联合DOS 推动DOS 发展DOS --

联盟域名:www.cn-dos.net  论坛域名:www.cn-dos.net/forum
DOS,代表着自由开放与发展,我们努力起来,学习FreeDOS和Linux的自由开放与GNU精神,共同创造和发展美好的自由与GNU GPL世界吧!

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
作者:
标题: [求助]如何处理空值 上一主题 | 下一主题
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『楼 主』:  [求助]如何处理空值

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 ]

2009-2-9 21:32
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
netbenton
银牌会员

批处理编程迷


积分 1916
发帖 752
注册 2008-12-28
来自 广西
状态 离线
『第 2 楼』:  

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 ]



精简
[你的+我的+他的]=>[大家的]    个人网志   
2009-2-9 21:42
查看资料  发送邮件  发短消息 网志  OICQ (37659560)  编辑帖子  回复  引用回复
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『第 3 楼』:  

netbenton的办法对目前a.txt中的内容能用。

但是,不好意思,我没有把a.txt内容展示完,只是摘录了一部份。
我的原文还好多列,且全部是数字,也有可能含有“5411”。所以必须用“|”分隔后,用“营业部”替换第3列中的5411,而其它列中的“5411”不替换成“营业部”。

还请帮忙。

2009-2-9 21:59
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
ficn
初级用户





积分 30
发帖 15
注册 2008-6-23
状态 离线
『第 4 楼』:  

是不是这样
@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 ]

2009-2-9 22:22
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复
netbenton
银牌会员

批处理编程迷


积分 1916
发帖 752
注册 2008-12-28
来自 广西
状态 离线
『第 5 楼』:  

@echo off
for /f "delims=" %%a in (zz.txt) do (
    set "var=%%a"
    setlocal enabledelayedexpansion
    set "var=!var:|5411|=|营业部|!"
    echo.!var!
    endlocal
  )
pause



精简
[你的+我的+他的]=>[大家的]    个人网志   
2009-2-9 22:28
查看资料  发送邮件  发短消息 网志  OICQ (37659560)  编辑帖子  回复  引用回复
hgx126
初级用户





积分 100
发帖 80
注册 2008-9-12
状态 离线
『第 6 楼』:  

个人觉得ficn的思路正适合我的想法。谢谢

2009-2-9 23:22
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

请注意:您目前尚未注册或登录,请您注册登录以使用论坛的各项功能,例如发表和回复帖子等。


可打印版本 | 推荐给朋友 | 订阅主题 | 收藏主题



论坛跳转: