中国DOS联盟论坛

中国DOS联盟

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

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

游客:  注册 | 登录 | 命令行 | 会员 | 搜索 | 上传 | 帮助 »
中国DOS联盟论坛 » DOS批处理 & 脚本技术(批处理室) » 请教如何去掉最后一个“,”
作者:
标题: 请教如何去掉最后一个“,” 上一主题 | 下一主题
windad
新手上路





积分 14
发帖 5
注册 2007-10-3
状态 离线
『楼 主』:  请教如何去掉最后一个“,”

做了一个sql server存储过程的批处理,有个问题请教 读取a.txt : POLICENO varchar(10) * PNAME varchar(10) ISADMIN char(2) PASSWD varchar(20) UNITID varchar(9) MOBILE varchar(20) PHONE varchar(20) EMAIL varchar(20) WADDRESS varchar(50) HADDRESS varchar(50) MEMO varchar(100) end 输出为b.txt : @POLICENO varchar(10), @PNAME varchar(10), @ISADMIN char(2), @PASSWD varchar(20), @UNITID varchar(9), @MOBILE varchar(20), @PHONE varchar(20), @EMAIL varchar(20), @WADDRESS varchar(50), @HADDRESS varchar(50), @MEMO varchar(100), 批处理命令是: for /f "tokens=1,2" %%a in (.\databaseinfo\%filename%.txt) do @echo @%%a %%b, >> .\%filename%\upAdd%filename%.txt 现在想去掉b.txt中最后一行末尾的的“,”或者在输入b.txt时最后一行没有”,“ 因为存储过程最后一行不能有“,”,而其他行末尾是必须的。 希望高手给代码能解释一下,好认真学习,谢谢大家!!! [ Last edited by windad on 2007-10-4 at 11:19 AM ]


2007-10-4 11:17
查看资料  发短消息 网志   编辑帖子  回复  引用回复
Climbing
铂金会员

网络独行侠


积分 6962
发帖 2753
注册 2003-4-16
来自 河北保定
状态 离线
『第 2 楼』:  

我想应该有两种办法: 第一种,是使用sed,应该很简单实现,但sed很难学。 第二种,先生成b.txt,然后再对b.txt进行第二次处理,将最后一行的“,"去掉即可。




偶只喜欢回答那些标题和描述都很清晰的帖子! 如想解决问题,请认真学习“这个帖子”和“这个帖子”并努力遵守,如果可能,请告诉更多的人!
2007-10-4 18:02
查看资料  发送邮件  访问主页  发短消息 网志  OICQ (653668)  编辑帖子  回复  引用回复
lxmxn
版主




积分 11386
发帖 4938
注册 2006-7-23
状态 离线
『第 3 楼』:  Sed版

 sed -e "/./!d;" -e "s/\([^[:space:]]\+[[:space:]]\+[^[:space:]]\+\).*$/\1,/;$s/,//" sql.txt|sed "$s/,//"


2007-10-4 19:24
查看资料  发送邮件  发短消息 网志   编辑帖子  回复  引用回复

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


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



论坛跳转: