SAS中文论坛

标题: 如何生成数值型变量 [打印本页]

作者: shiyiming    时间: 2009-11-19 12:41
标题: 如何生成数值型变量
&SYSDATE.里面存着是19nov2009 字符串,我想将其变成20091119的数字,应该如何操作,谢谢!
作者: shiyiming    时间: 2009-11-19 14:00
标题: Re: 如何生成数值型变量
[code:3r78eebv]
%macro fdate(fmt);
   %global fdate;
   data _null_;
      call symput("fdate",left(put("&sysdate"d,&fmt)));
   run;
   %put &sysdate --> &fdate;
%mend fdate;

%fdate(yymmddn8.) [/code:3r78eebv]
作者: shiyiming    时间: 2009-11-19 21:25
标题: Re: 如何生成数值型变量
谢谢你的帮助!
作者: shiyiming    时间: 2009-11-19 21:27
标题: Re: 如何生成数值型变量
哦 谢谢我哦知道了 请问 x=left(put("&sysdate"d,yymmddn8.)); 这样出来的为什么是字符变量啊,还有请问一下,我用MONTH("sysdate.) 这样总是报错 请问是为什么?
作者: shiyiming    时间: 2009-11-20 09:11
标题: Re: 如何生成数值型变量
第一个问题:因为用的是put函数。
第二个问题:因为SAS中宏变量值都是保存为字符型,而month函数要求的是日期型数据,也就是数值型的,所以,你可以先用input函数将该SAS系统宏按日期型导入后再进行月份取值。
作者: shiyiming    时间: 2009-11-20 09:20
标题: Re: 如何生成数值型变量
用input把字符变成数值型。
month函数的参数必须是a SAS date value。 "&sysdate"是字符,"&sysdate"d才是a SAS date value.

[code:3v8ww9w2]
data t;
sasdatec="&sysdate";
sasdaten="&sysdate"d;
chardate=put(sasdaten,yymmddn8.);
numdate=input(chardate,8.);
nummonth=month("&sysdate"d);
put _all_;
run;
proc contents data=t;run;[/code:3v8ww9w2]


关于D suffix for date values,以下from sashelp doc:
The value '21jan2001'D is a SAS date constant. To write a SAS date constant, enclose a date in quotation marks in the standard SAS form ddMMMyyyy and immediately follow the final quotation mark with the letter D. The D suffix tells SAS to convert the calendar date to a SAS date value.
作者: shiyiming    时间: 2009-11-20 09:44
标题: Re: 如何生成数值型变量
太感谢了,我终于明白了!
作者: shiyiming    时间: 2009-11-20 10:00
标题: Re: 如何生成数值型变量
不客气,大家一起学SAS。




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