全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
7934 2
2013-03-23
data _null_;
x=1234;
y=substr(x,1,2);
y1=substr(x,9,2);
z=substr(left(x),1,2);
put x= y= y1= z=;
run;
其中第四行“y1=substr(x,9,2)”,如果遇到“start”的数值比变量的字符数要多的话应该怎么做?比如这里变量的字符数只有4个,而“start”却是9.
日志是:
NOTE: 数字值已转换为字符值,位置:(行:列)。
      289:10   290:11   291:15
x=1234 y=  y1=12 z=12
NOTE: “DATA 语句”所用时间(总处理时间):
      实际时间         0.03 秒
      CPU 时间         0.03 秒
为什么y没有结果?
谢谢!
二维码

扫码加我 拉你入群

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

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

全部回复
2013-3-23 19:57:36
这里x为数值型变量,而substr是处理字符型变量的函数,这里SAS会将X自动转化为字符型变量,这时候会在1234前面添加空格的,x之前默认的informat为12.,故转化之后会在前面添加8个空格,然后就出现你上面的结果。这个其实跟下面这段code差不多的,希望对你有帮助。
data a;
x=1234;
y1=substr(x,9,2);
y=put(x,12.) ;
y2=substr(x,9,2);
run;
二维码

扫码加我 拉你入群

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

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

2013-3-23 20:51:54
Eternal0601 发表于 2013-3-23 19:57
这里x为数值型变量,而substr是处理字符型变量的函数,这里SAS会将X自动转化为字符型变量,这时候会在1234前 ...
谢谢你!这一个对我帮助很大 今天网上找资料一直没找到解答 很感谢你
二维码

扫码加我 拉你入群

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

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

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

说点什么

分享

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