全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
1247 3
2022-06-15
请教一下,如何删除字符串中的子字符串啊?用compress,会将所有列出的子字符串中的每一个汉字都删掉。举个例子:
data a;
  a1='我喜欢我的书包’;
  a2=compress(a1,'我的');
run;
结果a2的值是'喜欢书包',把最前面的我也删去了。
如果用替换,即tranwrd,会多出一个空格:
data a;
  a1='我喜欢我的书包’;
  a2=tranwrd(a1,'我的','');
run;
a2的结果是:'我喜欢 书包',我的被一个空格代替了。除非再使用一次compress,但会把原来就有的空格给去掉。
有没有好的办法啊?多谢!


二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

全部回复
2022-6-15 17:59:58
TRANWRD函数与TRANSTRN函数不同,因为TRANSTRN允许replacementstring的长度为零。当替换字符串的长度为零时,TRANWRD使用一个空格代替。
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2022-6-16 11:37:15
乐天天12300 发表于 2022-6-15 17:59
TRANWRD函数与TRANSTRN函数不同,因为TRANSTRN允许replacementstring的长度为零。当替换字符串的长度为零时 ...
长度为0的字符:trimn("")
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

2022-7-5 12:15:49
data a;
  a1='我喜欢我的书包';
  a2=TRANSTRN(a1,'我的',cats(''));
run;
二维码

扫码加我 拉你入群

请注明:姓名-公司-职位

以便审核进群资格,未注明则拒绝

相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

扫码加好友,拉您进群
各岗位、行业、专业交流群