网站大量收购闲置独家精品文档,联系QQ:2885784924

SAS学习系列08日期时间数据及数据格式..docx

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
SAS学习系列08日期时间数据及数据格式.

08. 日期时间数据及数据格式(一)SAS日期和时间数据SAS将所有的日期转化成一个以1960年1月1日为起点的数值(日期数值)。比如:January 1, 1960 0January 1, 1959 -365 January 1, 1961 366January 1, 2020 21915SAS处理日期数据包括:读取日期格式的数据,使用日期函数处理日期,按指定格式输出日期。读取日期格式的数据即按格式读入数据(formatted input),见系列03。比如,inputBirthDate 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,2005EarthDay05=22APR2005D;使用日期函数处理日期SAS提供的日期函数使得处理日期的操作大大简便。例如,today( )返回今天的日期;计算一本书应归还的剩余期限,就可以用:DaysOverDue=DateDue- today();用出生日期Birthdate计算年龄,可以用:CurrentAge = INT (YRDIF (BirthDate, TODAY(), AGE) );按按指定格式输出日期按指定格式输出日期时,还需要将日期数值转换成日期。例如,下面的FORMAT语句告诉SAS用WORDATE18.格式打印日期变量BirthDate。formatBirthDate WORDATE18.;例1图书馆有借书卡数据,Dates.dat,包含持卡人姓名、出生日期、卡办理日期,到期日:读取数据,计算剩余期限(DaysOverDue);计算持卡人年龄(CurrentAge);接着用IF语句来判断一个卡是否为新卡,在2012年1月1日之后办理的,为新卡。代码:datalibrarycards;infilec:\MyRawData\Library.datTRUNCOVER;input Name $11. + 1BirthDateMMDDYY10. +1IssueDateANYDTDTE10.DueDateDATE11.;DaysOverDue = DueDate - TODAY();CurrentAge = INT(YRDIF(BirthDate, TODAY(), AGE));ifIssueDate 01JAN2012DthenNewCard = yes;run;procprintdata = librarycards;formatIssuedateMMDDYY8.DueDateWEEKDATE17.;titleSAS 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:45DT;——日期时间常数值赋值;dhms(d,h,m,s)——由SAS日期值d、小时h、分钟m、秒s生成SAS日期时间值;datepart(dt) ——返回SAS日期时间值dt的日期部分;intnx(interval,from,n)——返回从from开始经过n个interval间隔后的SAS日期,

文档评论(0)

gangshou + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档