全部版块 我的主页
论坛 数据科学与人工智能 数据分析与数据科学 SAS专版
3975 7
2012-09-07
我有一个字符型的变量interest,需要转换成数值型的变量,保留小数点后两位,我想用input(interest,n.2) 但是我不知道这个字符的最大长度是多少,所以n不能确定,请问用什么方法可以正确的转换(不丢失位数)? 多谢多谢
二维码

扫码加我 拉你入群

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

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

全部回复
2012-9-7 06:48:09
可以设另一个变量 l_itrst=length(interest), 然后就sort一下就可以看到最长的那个了
二维码

扫码加我 拉你入群

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

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

2012-9-7 06:52:37
如果你要知道小数点前面最长有几位,也可以用int_itrs=index(interst, '.'),这样你就知道小数点在第几位了,然后同样可以知道最大的。

sample code:
data temp;
length char $30.;
input char $;
datalines;
14452162.34636
42.3
13455.345
6546778
45252.34
63578.23552536747
1.2
;
m=length(char);
n=index(char,'.');
run;
二维码

扫码加我 拉你入群

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

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

2012-9-7 06:54:35
但是这样还有个问题,当这个数没有小数点的时候,index()function返回的是0,那么你要取length()的值
二维码

扫码加我 拉你入群

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

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

2012-9-7 07:27:18
leonkd 发表于 2012-9-7 06:52
如果你要知道小数点前面最长有几位,也可以用int_itrs=index(interst, '.'),这样你就知道小数点在第几位了 ...
多谢多谢!假设我找到了char最长的长度是w,小数位最多的是d位,是不是直接用input(char,w.d)就可以了?
假设w=6 d=2,char有个值是1234,不会input之后变12.34吧?
我sas基础太差,看informat和format的说明已经看晕了。。。。。
二维码

扫码加我 拉你入群

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

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

2012-9-9 07:06:04
用round(interst, 0.01)
二维码

扫码加我 拉你入群

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

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

点击查看更多内容…
相关推荐
栏目导航
热门文章
推荐文章

说点什么

分享

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