使用SAS创建日历表

本文介绍如何在SAS中创建一个日历表,用于方便地处理和调用日期数据。日历表包含日期、年、月、日、星期几等字段,并标记了工作日和非工作日,可用于将日期转换为yyyymmdd格式并进行宏变量赋值,提高数据分析效率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在使用SAS进行数据分析时候经常需要对日期进行处理和调用,因为数据库的文件大部分都有yyyymmdd格式的日期后缀。借助日历表我们就可以更加灵活的对数据集进行调用。
下面我们使用SAS创建日历表calendar,该表共包含十个字段,序号n,日期date,年year,月month,日day,星期几weekday,是否是工作日isworkday,对应当月第几个工作日workday,当月工作日天数workdays,对应的工作日working_day(如果是工作日则对应自身,如果是非工作日则对应上一个工作日)

/*dd为上一年最后一个工作日,元旦假期对应到该工作日*/
%let dd = 20191230;

/*导入公共假期以及调班信息*/
data public;
    input date:date9. isworkday:best12. holiday_nm:$20.;
    format date yymmdd10.;
    datalines;
    '01jan2020'd 0 元旦
    '19jan2020'd 1 春节调班
    '24jan2020'd 0 春节
    '25jan2020'd 0 春节
    '26jan2020'd 0 春节
    '27jan2020'd 0 春节
    '28jan2020'd 0 春节
    '29jan2020'd 0 春节
    '30jan2020'd 0 春节
    '01feb2020'd 1 春节调班
    '04apr2020'd 0 清明
    '05apr2020'd 0 清明
    '06apr2020'd 0 清明
    
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值