SAS中文论坛

标题: 关于prxchange()的一个问题 [打印本页]

作者: shiyiming    时间: 2012-12-22 06:37
标题: 关于prxchange()的一个问题
data a;
input x $60. ;
x2=prxchange('s/([\d+]):(\w+\d*\w*):([^:])/$2/',-1,x);
cards;
935973:etl5dvh:FRD_ST.92.03s:ST.92.03_UAA:ST92ts
936023:etl3dvh:PRD.92.w:ST.92.03AAA:ST9203_CDC_E_W
936027:etl9dvh:TRD_ST.92ndowAAC:ST.92.03_SAS_Logg_Arkivering
936040:etl0dvh:KRDs:ST.05.00_AAA:ST0500_Hz_R_T_L
936042:etl1dvh:PReables:ST.05.00_SAABA:ST050_Hz_Par_Sit_LD
;
run;
我想得到被‘:’间隔开的string,比如第二个string: etl5dvh. 但如果用prxchange好像就不行,清大家帮忙看一下.
谢谢!
作者: shiyiming    时间: 2012-12-22 09:29
标题: Re: 关于prxchange()的一个问题
data a;
        input x $60. ;
        x2=prxchange('s/\d+:(\w+):.*/$1/',-1,x);
        x3=scan(x,2,':');
        cards;
935973:etl5dvh:FRD_ST.92.03s:ST.92.03_UAA:ST92ts
936023:etl3dvh:PRD.92.w:ST.92.03AAA:ST9203_CDC_E_W
936027:etl9dvh:TRD_ST.92ndowAAC:ST.92.03_SAS_Logg_Arkivering
936040:etl0dvh:KRDs:ST.05.00_AAA:ST0500_Hz_R_T_L
936042:etl1dvh:PReables:ST.05.00_SAABA:ST050_Hz_Par_Sit_LD
;
run;
作者: shiyiming    时间: 2013-1-22 06:06
标题: Re: 关于prxchange()的一个问题
谢谢Ferry.
但我想得到被:间隔的每个string,比如第二个、第三个等,不仅是第二个。
using prx functions(e.g. prxchange()) instead of scan().




欢迎光临 SAS中文论坛 (http://www.mysas.net/forum/) Powered by Discuz! X3.2