楼主: luckychll
42146 16

[程序分享] SAS中intck函数计算日期天数间隔等妙用 [推广有奖]

  • 14关注
  • 2粉丝

本科生

26%

还不是VIP/贵宾

-

威望
0
论坛币
229 个
通用积分
0.0602
学术水平
7 点
热心指数
15 点
信用等级
6 点
经验
242 点
帖子
68
精华
0
在线时间
83 小时
注册时间
2011-9-24
最后登录
2016-12-16

相似文件 换一批

+2 论坛币
k人 参与回答

经管之家送您一份

应届毕业生专属福利!

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

经管之家联合CDA

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

感谢您参与论坛问题回答

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

+2 论坛币

大家肯定知道自己几岁,度过了多少个季节。那多少人知道自己从出生到现在有多少个月,多少个周、多少天吗?SAS可以帮你解决,用intck函数,将你的出生日期和今天的日期放在下列函数就OK!试一试吧!可以应用到客户的入网时长等计算中。

data a;Format x date9. Y date9.;X='14feb1991'd;Y='21jan2013'd;year=Intck('year',x,y);qtr=Intck('qtr',x,y);month=Intck('month',x,y);week=Intck('week',x,y);day=Intck('day',x,y);put year= qtr= month= week= day=;run;


二维码

扫码加我 拉你入群

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

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

关键词:intck int format month FORMA 多少 出生日期

已有 2 人评分热心指数 收起 理由
eijuhz + 2 精彩帖子
webgu + 5 鼓励积极发帖讨论

总评分: 热心指数 + 7   查看全部评分

沙发
Imasasor 发表于 2013-1-22 16:49:10 |只看作者 |坛友微信交流群


%macro yourdays(birthday=);
data _null_;
file print;
y=today();
x=&birthday;
year=Intck('year',x,y);
qtr=Intck('qtr',x,y);
month=Intck('month',x,y);
week=Intck('week',x,y);
day=Intck('day',x,y);
put "你在这个世界上活了"year"年,"
    month"月," week"星期," day"天。";
run;
%mend;

%yourdays(birthday='08jun1988'd);


做得好一点,要用宏程序嘛,设置成今天就行了
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
mingfeng07 + 1 + 1 + 1 精彩帖子

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

欢迎加入亚太地区第一R&Python数据挖掘群: 251548215;

使用道具

藤椅
luckychll 发表于 2013-1-22 16:58:32 |只看作者 |坛友微信交流群
你真厉害,本来想用宏的,但给我弄错了。有空多多指教啊!
SAS 英雄会的新生Lybin,是不是有特别福利呢?
已有 1 人评分经验 论坛币 学术水平 热心指数 信用等级 收起 理由
Imasasor + 60 + 100 + 2 + 2 + 2 给你发点福利

总评分: 经验 + 60  论坛币 + 100  学术水平 + 2  热心指数 + 2  信用等级 + 2   查看全部评分

使用道具

板凳
slimdell 发表于 2013-1-22 17:10:25 |只看作者 |坛友微信交流群
不错,蛮有意思的
理论和实用结合
知乎专栏/微信公号同名:煮酒烹茶读书

使用道具

报纸
Imasasor 发表于 2013-1-22 17:16:46 |只看作者 |坛友微信交流群
又改了一下
优化了一下内容
  1. %macro yourdays(birthday=);
  2. ods listing close;
  3. ods html;
  4. data _null_;
  5. file print;
  6. time=time();
  7. y=today();
  8. x=&birthday;
  9. year=Intck('year',x,y);
  10. qtr=Intck('qtr',x,y);
  11. month=Intck('month',x,y);
  12. week=Intck('week',x,y);
  13. day=Intck('day',x,y);
  14. put 100*'*';
  15. put "现在是"y:yymmdd10."号" time:time5."分。";
  16. put;
  17. put "截止到目前,你在这个世界上活了"year"年,"
  18.     month"个月," week"个星期," day"天。";
  19. put;
  20. put "请珍惜你生命中的每一天!";
  21. put;
  22. put 100*'*';
  23. run;
  24. ods html close;
  25. ods listing;
  26. %mend;


  27. /*将以下日期改为你的生日,直接运行全部程序*/
  28. %yourdays(birthday='08jun1988'd);
复制代码
已有 1 人评分学术水平 热心指数 信用等级 收起 理由
webgu + 1 + 1 + 1 热心帮助其他会员

总评分: 学术水平 + 1  热心指数 + 1  信用等级 + 1   查看全部评分

欢迎加入亚太地区第一R&Python数据挖掘群: 251548215;

使用道具

地板
luckychll 发表于 2013-1-22 17:18:23 |只看作者 |坛友微信交流群
luckychll 发表于 2013-1-22 16:58
你真厉害,本来想用宏的,但给我弄错了。有空多多指教啊!
SAS 英雄会的新生Ly ...
太好了,福利真多[titter][titter],真开心!……

使用道具

7
luckychll 发表于 2013-1-22 17:24:05 |只看作者 |坛友微信交流群
Imasasor 发表于 2013-1-22 17:16
又改了一下
优化了一下内容
出来结果了,漂亮!

1.jpg (30.53 KB)

1.jpg

使用道具

8
munin 发表于 2014-5-11 17:03:36 |只看作者 |坛友微信交流群
Imasasor 发表于 2013-1-22 17:16
又改了一下
优化了一下内容
你好!冒昧打扰,不好意思!~
我是SAS初学者,小草一枚~~看到你编的这个程序觉得很有意思,可是不知道为什么,我电脑上运行时候,显示的是:“现在是2004-05-11 号16:57 分。”。。。其实现在的时间应该是2014年。不知道问题出在哪里。请指教!谢谢!

使用道具

9
Imasasor 发表于 2014-5-11 19:44:19 |只看作者 |坛友微信交流群
munin 发表于 2014-5-11 17:03
你好!冒昧打扰,不好意思!~
我是SAS初学者,小草一枚~~看到你编的这个程序觉得很有意思,可是不知道为 ...
你在破解SAS过程中用的破解方法修改了SAS获取的系统时间

简单来说你的SAS获得的系统时间不是你电脑的系统时间

所以不要管了
欢迎加入亚太地区第一R&Python数据挖掘群: 251548215;

使用道具

10
munin 发表于 2014-5-11 20:19:59 |只看作者 |坛友微信交流群
Imasasor 发表于 2014-5-11 19:44
你在破解SAS过程中用的破解方法修改了SAS获取的系统时间

简单来说你的SAS获得的系统时间不是你电脑的系 ...
懂了!谢谢!

使用道具

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

本版微信群
加好友,备注cda
拉您进交流群

京ICP备16021002-2号 京B2-20170662号 京公网安备 11010802022788号 论坛法律顾问:王进律师 知识产权保护声明   免责及隐私声明

GMT+8, 2024-4-26 12:43