Cn Holiday Calendar
/install cn-holiday-calendar
CN Holiday Calendar
Overview
Use this skill to answer date questions that depend on China's holiday schedule rather than a simple Monday-to-Friday rule. It handles statutory holidays, weekend make-up workdays, ordinary weekdays using official gov.cn notices, and calendar queries based on lunar-python.
Input Modes
Support two input shapes:
YYYY-MMYYYY-MM-DD
If the input is a month, return every date in that month with:
- Date
- Weekday
- Workday status
- Holiday or make-up shift name if present
- Lunar date summary
- Optional solar term summary if present
If the input is a single date, return the same fields for that date only.
When answering holiday/workday queries, always include the date's lunar summary by default and suggest that more calendar information is available. If the user asks for more, return the expanded calendar information for the date.
Workflow
Resolve the target year's holiday data first:
-
Look for
cache/YYYY.jsoninside this skill. -
If the file exists, use it to answer directly.
-
If the file does not exist, say
正在获取{年份}年最新节假日安排once, then callgov_search()fromscripts/query_holiday.pyto search gov.cn for节假日安排. -
Use this prompt to pick the best search result:
从下列查询结果的标题中选择最适配 {年份}节假日安排的一个,并给我对应查询结果的链接:{查询结果} -
Fetch the selected notice page body with
fetch_notice_body(url). -
Use this prompt to turn the notice body into JSON:
这是国务院关于节假日安排的通知,请从这个通知里解析出节假日放假的日期和因为假期调休为工作日的日期:{通知内容},以json的形式体现 -
Validate the JSON before caching it. At minimum, it should contain:
yearnotice_titlenotice_urlspecial_days
-
Save the validated result as
cache/{年份}.json. -
If you need a one-shot helper, use
refresh_year(year)fromscripts/query_holiday.py, or the CLIrefreshcommand. -
For lunar calendar data, use
lunar-pythonthroughscripts/query_holiday.py.
Interpretation Rules
- Do not infer workday status from weekdays alone.
- Treat weekend make-up shifts as workdays.
- Treat holiday rest days as non-workdays even if they fall on Monday to Friday.
- If the cache has a matching date, use it first.
- If the cache does not list a date, fall back to the normal weekday rule: Monday to Friday are workdays, Saturday and Sunday are not.
- Do not mention cache hits, cache refresh, or other internal retrieval steps in the user-facing answer; only present the final skill result.
- If you need a progress line, use only
正在获取{年份}年最新节假日安排and nothing about cache. - For normal answers, include the lunar date summary and the most relevant solar term information if available. If the user explicitly asks for more calendar detail, return the expanded lunar calendar information.
Output Format
For a month query, output a compact table:
dateweekdayworkdaykindholidaylunarjieqi
For a single-date query, output a short structured summary with the same fields.
For expanded calendar output, include a calendar object with the full lunar profile returned by lunar-python.
Lunar Coverage
The lunar-python package can provide more than lunar date and solar terms. Useful date-level information commonly available through the package includes:
- Lunar date strings and full lunar descriptions
- Current, previous, and next solar term information
- Heavenly stems and earthly branches for year, month, day, and time
- Zodiac information
- Lunar day auspicious and inauspicious activities
- Solar, lunar, and traditional festival names
- Eight characters and related calendar metadata
- Additional Chinese calendar metadata such as fu periods, seasons, and other traditional calendar attributes
Use the full calendar profile only when the user asks for more detail. For standard holiday/workday answers, keep the response concise and surface the lunar summary by default.
Script
Use scripts/query_holiday.py as the primary entry point for deterministic search, notice-body extraction, cache loading, cache refresh, and date classification.
- Make sure OpenClaw is installed (local or Docker)
- Run the install command in chat:
/install cn-holiday-calendar - After installation, invoke the skill by name or use
/cn-holiday-calendar - Provide required inputs per the skill's parameter spec and get structured output
What is Cn Holiday Calendar?
Query gov.cn Chinese holiday notices to determine workdays, holidays, and make-up workdays. Use when the user needs to check whether a specific date is a wor... It is an AI Agent Skill for Claude Code / OpenClaw, with 0 downloads so far.
How do I install Cn Holiday Calendar?
Run "/install cn-holiday-calendar" in the OpenClaw or Claude Code chat to install it in one step — no extra setup required.
Is Cn Holiday Calendar free?
Yes, Cn Holiday Calendar is completely free, licensed under MIT-0. You can download, install and use it at no cost.
Which platforms does Cn Holiday Calendar support?
Cn Holiday Calendar is cross-platform and runs anywhere OpenClaw / Claude Code is available (cross-platform).
Who created Cn Holiday Calendar?
It is built and maintained by BlueWorld415 (@blueworld415); the current version is v1.0.0.