- 1、本文档共10页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 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日期,
您可能关注的文档
- sap总账科目的设置与维护..doc
- SAP模块调查问卷..doc
- SAP标准和用户字段应用..doc
- Sarason考试焦虑量表(TAS)..doc
- sars建模论文..doc
- SASBASE考前备注..doc
- SAS专业单词1..doc
- SAS中用到的SQL语法及结构..doc
- sas宏收集资料..doc
- SAS学习(初识)..doc
- 迪卡侬秋季系列产品社交媒体整合传播方案.pptx
- 2025年(精华版)国家开放大学电大《建设项目管理》机考5套真题题库及答案1_.pdf
- 2025年(精华版)2套必威体育精装版国家开放大学电大《管理学基础》机考终结性真题题库及精品.pdf
- 大型房地产置业顾问礼仪培训.pptx
- 2025年(精华版)国家开放大学电大《工程经济》机考3套真题题库及答案8.pdf
- 2025年(环境管理)环境艺术 .pdf
- 2025年(电大基于网络化考试历年真题模块)优质431_数控机床_模块第五套.pdf
- 2025年(物理)物理电压和电阻专项测试题(含答案解析) .pdf
- 2025年(记述文)关于兴趣的中考记叙文 .pdf
- 2025年(部编版)《祖先的摇篮》完美教案.pdf
文档评论(0)