楼主: lone02
1748 3

[问答] 求助:宏日期变量在data步的时候不是日期格式 [推广有奖]

  • 0关注
  • 0粉丝

初中生

42%

还不是VIP/贵宾

-

威望
0
论坛币
19 个
通用积分
0
学术水平
0 点
热心指数
0 点
信用等级
0 点
经验
125 点
帖子
17
精华
0
在线时间
10 小时
注册时间
2011-10-21
最后登录
2015-6-3

楼主
lone02 在职认证  发表于 2013-9-10 16:18:21 |AI写论文

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

求职就业群
赵安豆老师微信:zhaoandou666

经管之家联合CDA

送您一个全额奖学金名额~ !

感谢您参与论坛问题回答

经管之家送您两个论坛币!

+2 论坛币
代码如下:


%let G_SAS_DT='1JUN2012'd;
%LET enddate=%sysfunc(putn(%sysfunc(intnx(month,&G_SAS_DT,0,e)),yymmdd10.));

data temp;
        x=&enddate;
run;


但是temp数据集里的x的值是1976,而不是2012-06-30.

求高手解答下
二维码

扫码加我 拉你入群

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

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

关键词:data步 日期变量 Data sysfunc 求高手解答

沙发
wwang111 发表于 2013-9-10 17:01:14
x="&enddate";
只有一个罗纳尔多

藤椅
moyunzheng 发表于 2013-9-11 08:46:37
直接用format好一些吧
  1. %let G_SAS_DT='1JUN2012'd;
  2. %LET enddate=%sysfunc(intnx(month,&G_SAS_DT,0,e));

  3. data temp;
  4.         x=&enddate;
  5.                 format x yymmdd10.;
  6. run;
复制代码

板凳
bobguy 发表于 2013-9-14 06:50:50
The correct is,
%let G_SAS_DT='1JUN2012'd;
%LET enddate=%sysfunc(putn(%sysfunc(intnx(month,&G_SAS_DT,0,e)),yymmdd10.));
%put "&enddate";

data temp;
        x=input("&enddate",yymmdd10.);
     put x= x= date9. ;
run;

您需要登录后才可以回帖 登录 | 我要注册

本版微信群
加好友,备注cda
拉您进交流群
GMT+8, 2026-1-3 05:45