学习SAS的时候,input和put函数是非常常用的两个功能,而且初学者还容易搞混或者分不清楚。
上次我讲了input中加问号的作用,今天我就再细讲一下这两个函数,以及我发现的一个错误。
你只要记住:
input是将SAS变量值从字符型转换成数值型;而put是将数值型转换成字符型 就够了。
data test;
a=1;
b="sas";
c="3";
run;
sas变量类型就两个,一个数值型,一个字符型。看下图
可以看到数值型是在方框的右边;字符型是顶格靠近方框的左边。
我们在将数值型变量转换成字符型的时候,最好和strip函数一起使用,要不然的话转换后值前后会有很多空格,而不是顶格输出。就像下面的图片那样:
data test2;
set test;
d=put(a,best.);
run;
加上strip之后,显示正常。
d=strip(put(a,best.));
当然put和input还能用于日期格式的转换,后面专门写一篇文章介绍SAS中的日期格式。这次就简单举个日子。
读入数据:
data dat;
input dat $19.;
cards;
2018-02-13
2021-5-18
;
run;
data dat2;
set dat;
dat2=input(dat,yymmdd10.);
run;
如果input和put一起用:
dat2=strip(put(input(dat,yymmdd10.),yymmdd10.));
可能你会觉得dat和dat2不是长得一样吗?有必要做这些转换吗?其实dat只是普通的字符串,而dat2在SAS看来却是日期,相当于带有日期format的字符串。
下面讲一下我发现的一个错误:
有时候会遇到字符型也存在空格的情况,导致字符串拼接的时候达不到我们的要求,于是我也会用上strip,就像下面这样。
e=strip(b)||strip(c);
这样是不会报错的,但是如果我想将c转换成数值型,这时候问题就出现了。
d=strip(input(c,best.));
虽然显示出来了,但是却是字符型,而且报错了
但是如果只是简单的转换成数值型就没问题
d=input(c,best.);
用拼接符将变量d和b拼接,
f=strip(d)||strip(b);
还是报上面的错,但是如果用catx函数连接,就不会报错。所以我很喜欢用catx函数。
e=catx("-",d,b);
写了这么多,就是想讲大家在转换字符型的数字的时候,这时候就不能strip和input一起用,可以先转换成数值型再用strip函数,分开处理,而且更不要想着把字符"sas"转换成数值型,sas都懒得理你,字符型的数字还好说。
源程序:自己可以复制到SAS跑跑看。
data test2;
set test;
d=input(c,best.);
e=catx("-",d,b);
f=strip(d)||strip(b);
run;