目的

判断一天是否为节假日。

在区分不同的工作场景时,这个变量是比较有用的。

基础数据如何获取?

节假日查询

百度搜索节假日,国务院放假发文地址

 https://www.gov.cn/zhengce/zhengceku/202310/content_6911528.htm

节假日数据获取

方式一:手动维护日期数据

1.初始化数据库表sql
drop database if exists kaoqin;
create database kaoqin;

use kaoqin;
CREATE TABLE `no_work_day` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `day` varchar(255) DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8;
  • 1.
  • 2.
  • 3.
  • 4.
  • 5.
  • 6.
  • 7.
  • 8.
  • 9.
2. 初始化数据

建议这种方式,可以更加灵活。

可以存储每一天的数据,也可以简单些只配置特殊的节假日。

方式2:三方接口

调用api查询(2020年及之前的年份才能用此api)

首先查询百度万年历节接口(其中包含全年节假日数据),得到json数据 (全年节假日信息在json的holiday中,query=2020,其实默认就是202001,其他月份的万年历请求如query=202004)

请求的api:

 https://sp0.baidu.com/8aQDcjqpAAV3otqbppnN2DJv/api.php?query=2020&resource_id=6018

除了节假日,还有哪些因素可能影响工作日的判断?

除了节假日,还有几个因素可能影响工作日的判断:

  1. 公司政策:不同的公司可能有不同的工作日安排,例如某些公司可能有弹性工作制度,允许员工在某些日子远程工作或选择休息日。

  2. 行业特性:某些行业可能因为其特殊性而有不同的工作日安排。例如,零售和服务业在周末和节假日可能更忙碌,因此这些日子可能被视为工作日。

  3. 地区差异:不同地区的工作习惯和文化可能影响工作日的安排。例如,在某些地区,可能存在半天工作日或特定的宗教节日。

  4. 季节性变化:在某些行业,如农业或旅游业,工作日可能会根据季节性需求进行调整。

  5. 特殊事件:如自然灾害、突发公共卫生事件(如疫情)或其他紧急情况可能影响正常的工作日安排。

  6. 政府政策:政府可能会因为特殊原因调整工作日,例如为了缓解交通压力而实行的错峰上下班政策。

  7. 员工个人情况:员工的个人情况,如病假、年假、产假等,也可能影响特定日期是否为工作日。

  8. 国际日期变更:对于跨国公司,不同国家的节假日和工作日安排可能不同,需要综合考虑。

  9. 时区差异:对于全球分布的团队,时区差异可能意味着某些地区的工作日与其他地区不同。

  10. 宗教节日:不同宗教有不同的节日,这些节日可能会影响某些员工的工作日。

在编写程序判断工作日时,需要根据具体情况考虑这些因素,并相应地调整逻辑以适应不同的需求。