Board logo

标题: 请教如何去掉最后一个“,” [打印本页]

作者: windad     时间: 2007-10-4 11:17    标题: 请教如何去掉最后一个“,”

做了一个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 ]
作者: Climbing     时间: 2007-10-4 18:02
我想应该有两种办法:

第一种,是使用sed,应该很简单实现,但sed很难学。

第二种,先生成b.txt,然后再对b.txt进行第二次处理,将最后一行的“,"去掉即可。
作者: lxmxn     时间: 2007-10-4 19:24    标题: Sed版


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