ysp/holiday

查询是否节假日 农历 节气 中国 2倍工资 3倍工资

v1.0.1 2024-03-21 07:38 UTC

This package is auto-updated.

Last update: 2024-12-21 09:05:32 UTC


README

准确度说明

1,目前包里已包含2001年至2050年的节假日信息,农历节气可查询1970年-2050年的,节假日可查询2011年-2050年(自动跟随政府公布的信息更新)

2,查询当前时间和之前的节假日信息,会走缓存的数据信息,因为已经过去的假期是已经固定的

3,查询未来的节假日,如果缓存的数据超过3天(即使是临时性放假,也至少会提前3天公布吧),会自动从百度拉取最新的假期信息,如果拉取失败会继续走缓存

4,查询未来的节假日,如果没有缓存,会自动从百度拉取最新的假期信息,如果拉取失败会抛出异常

5,对于要求比较高的,可以先强制刷新数据再查询

使用方法

安装扩展

composer require ysp/holiday

使用方法

1,判断当前日期是否是节假日
use Ysp\Holiday;

$holiday=new Holiday();

$result = $holiday->isHoliday(time());

返回结果 true 或 false,此函数有第二个参数type,可选值为
TYPE_ALL = 1; //全部节假日 包括周末 默认
TYPE_WEENEND = 2; //普通的周末,2倍工资的那种
TYPE_HOLIDAY = 3; //只包含节日,3倍工资的那种,节日当天
TYPE_VACATION = 4; //节假日,节日+节日前后调休的部分

如果只判断节假日,不考虑周末

$result = $holiday->isHoliday(time(),Holiday::TYPE_VACATION);
2,获取时间段内假期天数
$result = $holiday->count(strtotime('2020-1-1'),strtotime('2020-12-30'),Holiday::TYPE_VACATION);
// 返回30
3,获取时间段内假期列表
$result = $holiday->countDate(strtotime('2020-1-1'),strtotime('2020-3-1'),Holiday::TYPE_VACATION);
//返回数组
["2020-01-01","2020-01-24","2020-01-25","2020-01-26","2020-01-27","2020-01-28","2020-01-29","2020-01-30","2020-01-31","2020-02-01","2020-02-02"]
4,节假日名称
$result = $holiday->nowHoliday(strtotime('2020-1-1'));
// 元旦节
$result = $holiday->nowHoliday(strtotime('2020-1-24'));
// 春节
$result = $holiday->nowHoliday(strtotime('2020-2-1'));
// 春节
$result = $holiday->nowHoliday(strtotime('2020-10-1'));
// 国庆节 当节假日重复时,以阳历节假日优先
5,获取农历日历
$result = $holiday->getLunar(strtotime('2020-10-1'));
// 返回数组 
[
    "year" => "2020",
    "month" => "8",
    "day" => "15",
    "lmonth" => "八",
    "ldate" => "十五",
    "gz_year" => "庚子",
    "gz_month" => "乙酉",
    "gz_date" => "丁丑",
]
6,获取节气
$result = $holiday->term(strtotime('2020-5-20'));
// 小满
7,刷新数据
$result = $holiday->update(strtotime('2020-5-20'));
// 强制刷新当前月份及前后1个月的数据 返回逻辑值