- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SAS学习系列08 日期时间数据及数据格式
08. 日期时间数据及数据格式
(一)SAS日期和时间数据
SAS将所有的日期转化成一个以1960年1月1日为起点的数值(日期数值)。比如:
January 1, 1960 0
January 1, 1959 -365
January 1, 1961 366
January 1, 2020 21915
SAS处理日期数据包括:读取日期格式的数据,使用日期函数处理日期,按指定格式输出日期。
读取日期格式的数据
即按格式读入数据(formatted input),见系列03。比如,
input BirthDate MMDDYY10.;
设定默认的百年
07/04/76这样的数据可能是1976,也可能是2076、1776。因此需要YEARCUTOFF = 来指定一个一百年的第一年,默认的是1920年。
例如,下面的语句就是告诉SAS将一个两位年份的日期解释为1960年到2049年之间:
OPTIONS YEARCUTOFF = 1950;
SAS日期的存取
日期一旦被以SAS以日期格式读取之后,就将此数据像其他数值数据一样用在表达式中(日期数值)。
例如,像为图书馆的书设定21天的还书日期,只需要在借书日期上加上21:
DueDate = CheckDate + 21;
通过引号和字母D,可以将一个日期当作常数来使用,下面的代码创建了一个EarthDay05的日期变量,其值等于April 22, 2005
EarthDay05=22APR2005D;
使用日期函数处理日期
SAS提供的日期函数使得处理日期的操作大大简便。
例如,today( ) 返回今天的日期;
计算一本书应归还的剩余期限,就可以用:
DaysOverDue = DateDue - today();
用出生日期Birthdate计算年龄,可以用:
CurrentAge = INT (YRDIF (BirthDate, TODAY(), AGE) );
按按指定格式输出日期
按指定格式输出日期时,还需要将日期数值转换成日期。
例如,下面的FORMAT语句告诉SAS用WORDATE18.格式打印日期变量BirthDate。
format BirthDate WORDATE18.;
例1 图书馆有借书卡数据,Dates.dat,包含持卡人姓名、出生日期、卡办理日期,到期日:
读取数据,计算剩余期限(DaysOverDue);计算持卡人年龄(CurrentAge);接着用IF语句来判断一个卡是否为新卡,在2012年1月1日之后办理的,为新卡。
代码:
data librarycards;
infile c:\MyRawData\Library.dat TRUNCOVER;
input Name $11. + 1 BirthDate MMDDYY10. +1 IssueDate ANYDTDTE10. DueDate DATE11.;
DaysOverDue = DueDate - TODAY();
CurrentAge = INT(YRDIF(BirthDate, TODAY(), AGE));
if IssueDate 01JAN2012D then NewCard = yes;
run;
proc print data = librarycards;
format Issuedate MMDDYY8. DueDate WEEKDATE17.;
title SAS Dates without and with Formats;
run;
运行结果:
程序说明:
BirthDate变量没有指定输出格式,默认输出日期数值;
“ANYDTDTE10.” 以各种格式(非单一格式)读入日期;
歧义日期值,例如01-02-03,可以用DATESTYLE = MDY来设置(默认是MDY)。
时间数据
SAS的时间数值(time),表示从当天零点开始到当前时间的秒数,大小介于0和 86400之间。
hms(h,m,s) ——由小时h、分钟m、秒s生成SAS时间值;
t1 = ‘8:45’T;——时间常数值赋值;
hour(time);——返回时间数值的小时数;minute, second类似;
SAS还有日期时间数值(datetime),表示从1960年1月1日零点到当前时刻的秒数。datetime 对应的几种格式:
30May2000:10:03:17.2 DATETIME20.
30May00 10:03:17.2 DATETIME18.
30May2000/10:03 DATETIME15.
conn = 01Feb2011:8:45D
您可能关注的文档
- LC-ICP-MS对农残中代森锌检测实验方案.doc
- LAB02_多项式值计算及其收敛性实验.doc
- K03《结构力学(科)》复习题.doc
- K20+590钢筋盖板涵施工技术方案(终版).doc1.doc
- KIS到KIS专业v8.1升级工具说明.doc
- K6(下)数学第五有理数复习课教案—0519.doc
- KO+032.16KO+298.34管道工程专项施工方案(已修改).doc
- KSHR-WI-A-010劳动防护用品管理办法_V1.1.doc
- LED光源灯具光通测量的不确定度因素分析.doc
- LED控制装置标准主要安全要求的识别及应用.doc
- S-MR-14-06 A.0 受限空间管理规定.docx
- Sdeer圣迪奥服有限责任公司招聘及选拔方案.doc
- SCADA-EMS统在电力调度自动化工程中的实践.doc
- Schiff碱论文酰腙化合物及1-(2-吡啶基)乙酮类Schiff碱配合物的合成、表征及生物活性研究.doc
- SB002浙江省地税(费)纳税综合申报表及附表.doc
- SBS改性AC-2沥青砼中面层施工方案.doc
- proteus在《机原理》 教学中的应用.doc
- SGB-62040刮板输送机技术规格书4套.doc
- SGBZ-0635架空线路的立杆施工工艺标准.doc
- SEPCOⅢ-NPNDA-SMP-0003危害辨识、风险评价和控制管理程序.doc
原创力文档


文档评论(0)