back
loading skill details...
Daily Chinese Almanac Image Generator - Create traditional Huangli calendar images with zodiac fortune, fengshui tips, auspicious timing, and dressing advice...
---
name: almanac-creator
displayName: Almanac Creator
description: Daily Chinese Almanac Image Generator - Create traditional Huangli calendar images with zodiac fortune, fengshui tips, auspicious timing, and dressing advice for social media publishing (Toutiao/Douyin/Xiaohongshu)
version: 3.0.4
author: Digital Transformation Team
tags: [almanac, chinese-calendar, huangli, zodiac, fengshui, image-generator, lunar-python, multi-template, batch-generator, config-file, universal]
---
# Almanac Creator (黄历制作技能)
> **标准版本**: almanac-image-standard.md V3
> **适用范围**: 每日黄历图片生成
> **输出规格**: 3 页 PNG 图片(1080x1400 像素)
> **最新版本**: V3.0.3 抖音优化版(2026-04-18)
---
## 🎯 技能概述
本技能用于按照标准化流程制作每日黄历图片(V3 紧凑版),包含:
- **第 1 页**: 封面 + 宜忌 + 生肖 + 完整干支纪年
- **第 2 页**: 财神方位 + 吉时查询 + 养生建议
- **第 3 页**: 穿衣建议 + 黄历科普 + 传统故事
适用于今日头条(三图轮播)、抖音/小红书(单图发布)等平台。
### V3.0.3 更新内容(2026-04-18 抖音优化版)⭐⭐⭐⭐⭐
**抖音算法适配优化**:
- ✅ **互动引导**: 第2、3页底部添加"👍 点赞接好运 💬 评论区留下你的生肖 ➕ 关注每日更新"
- ✅ **生肖图标**: 生肖运势添加emoji图标(🐭🐮🐯🐰🐲🐍🐴🐑🐵🐔🐶🐷)
- ✅ **用户体验**: 提升视觉吸引力和互动率
### V3.0.2 更新内容(2026-04-12 干支修复版)⭐⭐⭐⭐⭐
**紧急修复**: 干支计算错误(月柱/日柱)
| 更新项 | 说明 |
|--------|------|
| 🔧 **月柱修复** | 根据节气计算月柱(修复 lunar-python 农历月问题) |
| 🔧 **日柱修复** | 使用 Solar.fromYmd 转换(修复 Lunar.fromYmd 农历日期问题) |
| ✅ **向后兼容** | 完全兼容 V3.0.1,建议所有用户升级 |
**问题说明**:
- V3.0.1 使用 `Lunar.fromYmd()` 导致日期转换错误
- lunar-python 的 `getMonthInGanZhi()` 返回农历月干支,不是节气月干支
- 修复后:2026-04-13 = 丙午年 壬辰月 丁巳日 ✅
### V3.0.2 更新内容(2026-05-22 lunar-python API 修复版)⭐⭐⭐⭐⭐
**紧急修复**: `Lunar.fromYmd` 把公历日期当农历解析,导致日期越界
| 更新项 | 说明 |
|--------|------|
| 🔧 **API 误用修复** | `Lunar.fromYmd(y,m,d)` 的参数是**农历**年月日,不是公历 |
| 🔧 **正确用法** | 公历→农历转换必须用 `Solar.fromYmd(y,m,d).getLunar()` |
| 🔧 **影响范围** | 脚本中 2 处误用(年柱获取 + 宜忌获取) |
| ✅ **向后兼容** | 完全兼容 V3.0.1,建议所有用户升级 |
**问题说明**:
- `Lunar.fromYmd(2026, 5, 30)` 被解析为"农历 2026 年 5 月 30 日"
- 2026 年农历五月是小月(只有 29 天),传入 day=30 直接抛异常
- 即使没报错(如 5 月 23 日),干支/宜忌/生肖也对应错误的农历日期
- 修复后:所有日期统一用 `Solar.fromYmd().getLunar()` 正确转换
**教训**: lunar-python 的 API 命名容易混淆,公历→农历一律用 `Solar.fromYmd().getLunar()`
### V3.0.1 更新内容(2026-04-12 通用化版)⭐⭐⭐⭐⭐⭐
**使用示例**:
```bash
# 单日生成
python generate_almanac.py --date 2026-04-12
# 批量生成 7 天
python generate_almanac.py --batch 7 --start-date 2026-04-12
# 指定配置文件
python generate_almanac.py --date 2026-04-12 --config my_config.yaml
```
### V2.3.1 更新内容(2026-04-11 季节故事修复版)⭐⭐⭐⭐⭐
### V2.3 更新内容(2026-04-11 大字体优化版)⭐⭐⭐⭐⭐
| 更新项 | 说明 |
|--------|------|
| ✅ **字体全面加大** | 栏目题 55→60px,正文 45→48px,故事/养生正文 40→44px |
| ✅ **行间距优化** | 1.3→1.4,提升阅读舒适度 |
| ✅ **间距调整** | 栏目/内容/分隔线间距加大 2-3px |
| ✅ **可读性提升** | 整体可读性提升约 15%,中老年用户友好 |
| ✅ **无需分页** | 保持 3 页完整布局,内容不裁剪 |
### V2.2 更新内容(2026-04-10 多模板版)⭐⭐⭐
| 更新项 | 说明 |
|--------|------|
| ✅ **集成 lunar-python** | 使用 lunar-python(lunar-java 的 Python 版本) |
| ✅ **干支计算升级** | 使用 lunar-python 准确计算(替代 100+ 行映射表) |
| ✅ **宜忌准确性提升** | 使用 lunar-python 传统算法(替代本地池) |
| ✅ **5 套模板轮换** | 传统/现代/喜庆/典雅/清新,每日自动轮换 |
| ✅ **24 节气故事** | 故事池从 4 个扩展到 24 个(按季节分类) |
| ✅ **输出目录修复** | 支持多用户、跨平台,智能路径检测 |
| ✅ **生肖黑榜修复** | 智能检测重复,确保红黑榜无冲突 |
| ✅ **传统元素支持** | 彭祖百忌、纳音、星宿、建除十二值星、九星 |
| ✅ **代码优化** | 减少 150+ 行硬编码,更易维护 |
### V2.1 更新内容(2026-04-10 修复版)⭐
| 更新项 | 说明 |
|--------|------|
| ✅ 生肖运势 | 基于六合三合相冲相害计算,吉凶正确 |
| ✅ 吉时查询 | 使用十二神值时(青龙明堂等) |
| ✅ 财神方位 | 根据日干准确计算方位 |
### V3 更新内容(2026-04-09)
| 更新项 | 说明 |
|--------|------|
| ✅ 紧凑布局 | 全局段间距离缩小 10-15px |
| ✅ 完整干支 | 第 1 页增加年柱 + 月柱 + 日柱 |
| ✅ 吉时查询 | 第 2 页增加时辰吉凶(仅地支名称) |
| ✅ 穿衣建议 | 第 3 页增加五行颜色搭配 |
---
## 📐 图片规格标准
### 基础参数
| 参数 | 值 | 说明 |
|------|-----|------|
| **宽度** | 1080 像素 | 适配手机竖屏 |
| **高度** | 1400 像素 | 内容舒展不拥挤 |
| **比例** | 9:12.96 | 接近 9:13 竖版 |
| **格式** | PNG | 高质量无损压缩 |
| **质量** | 95 | 平衡文件大小与质量 |
| **文件大小** | 150-250 KB/页 | 适合网络传播 |
### 背景与边框
```python
# 背景色
BACKGROUND_COLOR = '#F8F0E6' # 温暖的米黄色(宣纸质感)
# 双层边框
外层边框:8px 中国红 (#8B0000)
内层边框:2px 金色 (#D4AF37)
边距:外层 10px,内层 22px
```
---
## 📝 字体与颜色标准
### 字体层级
| 用途 | 字号 | 颜色 | 示例 |
|------|------|------|------|
| **主标题** | 90px | #8B0000 | 每日黄历 |
| **副标题** | 65px | #2C2C2C | 2026 年 4 月 8 日 星期三 |
| **栏目题** | 55px | #8B0000 | 今日宜/生肖运势 |
| **正文** | 45px | #2C2C2C | 宜忌内容 |
| **小字** | 38px | #999999 | 底部信息 |
### 字体选择
```python
# 优先使用 Windows 黑体
font = ImageFont.truetype('C:/Windows/Fonts/simhei.ttf', size)
# Mac/Linux 备选
font = ImageFont.truetype('/System/Library/Fonts/PingFang.ttc', size)
font = ImageFont.truetype('/usr/share/fonts/noto-cjk/NotoSansCJK-Regular.ttc', size)
```
### 颜色标准
| 颜色 | 色值 | 用途 |
|------|------|------|
| **中国红** | #8B0000 | 标题、边框、重点信息 |
| **亮红色** | #C41E3A | 宜/红榜/强调内容 |
| **墨黑色** | #2C2C2C | 正文、日期、常规信息 |
| **金色** | #D4AF37 | 边框、分隔线、装饰 |
| **米黄色** | #F8F0E6 | 背景色 |
| **浅灰色** | #999999 | 底部信息、辅助说明 |
---
## 🛠️ 制作流程
### 步骤 1:准备黄历数据
获取当日黄历信息:
- 公历日期 + 星期
- 农历日期(年 + 月 + 日)
- 节气信息
- 今日宜忌
- 生肖运势(红榜 3 个 + 黑榜 3 个)
- 财神方位(喜神/福神/财神/胎神)
**数据来源**:
- 黄历 API(推荐):`https://api.qingyunke.com/api.php?key=free&appid=01&msg=今日黄历`
- 手动查询万年历
- 参考昨日黄历格式
### 步骤 2:生成图片
使用脚本生成 3 页图片:
```bash
# 方法 1:使用整合脚本(推荐)
python scripts/generate_almanac.py --date 2026-04-08
# 方法 2:分页面生成
python scripts/generate_almanac_page1.py --date 2026-04-08
python scripts/generate_almanac_page2.py --date 2026-04-08
python scripts/generate_almanac_page3.py --date 2026-04-08
```
### 步骤 3:质量检查
**视觉检查清单**:
- ✅ 双层边框完整(外红内金)
- ✅ 所有文字居中对齐
- ✅ 字体大小符合标准
- ✅ 颜色使用正确
- ✅ 行间距舒适(不拥挤)
- ✅ 分隔线位置合理
- ✅ 底部信息完整
- ✅ 文件大小 150-250KB
**内容检查清单**:
- ✅ 日期信息准确(公历 + 农历)
- ✅ 宜忌内容完整
- ✅ 生肖运势正确(红榜/黑榜各 3 个)
- ✅ 财神方位准确
- ✅ 养生建议合理
- ✅ 科普内容准确
- ✅ 故事内容完整
- ✅ 底部免责声明存在
### 步骤 4:生成发布文案
**今日头条文案**:
```
标题:【{日期}】{农历} 每日黄历
正文:
今日黄历已更新!
📅 公历:{日期}
🌙 农历:{农历}
✅ 宜:{宜内容}
❌ 忌:{忌内容}
🏆 红榜:{红榜生肖}
⚠️ 黑榜:{黑榜生肖}
更多详情见图👆
#每日黄历 #传统文化 #生肖运势
```
**抖音/小红书文案**:
```
【{日期}黄历】{节气信息}✨
今日红榜生肖:{红榜}
黑榜生肖:{黑榜}
财神在{财神方位},记得朝这个方向求财哦💰
#黄历 #每日运势 #传统文化
```
### 步骤 5:发布
| 平台 | 发布时间 | 使用图片 | 文案 |
|------|----------|----------|------|
| **今日头条** | 12:00-14:00 | 3 页轮播 | 完整版 |
| **抖音** | 18:00-21:00 | 第 1 页 | 精简版 |
| **小红书** | 20:00-22:00 | 第 1 页 | 精简版 |
---
## 📁 文件命名标准
```
{日期}_黄历 [_页面].png
示例:
- 2026-04-08_黄历.png (第 1 页)
- 2026-04-08_黄历_养生.png (第 2 页)
- 2026-04-08_黄历_故事.png (第 3 页)
```
---
## 📋 内容布局标准
详见 [references/almanac-image-standard.md](references/almanac-image-standard.md)
### 第 1 页:封面 + 宜忌 + 生肖
- 每日黄历标题
- 公历 + 农历日期
- **完整干支纪年**(年柱 + 月柱 + 日柱)⭐ V3 新增
- 节气信息
- 今日宜(分 2 行)
- 今日忌
- 红榜生肖(3 个,带🥇🥈🥉)
- 黑榜生肖(3 个)
### 第 2 页:财神 + 吉时 + 养生
- 财神方位(喜神/福神/财神/胎神)
- **吉时查询**(12 时辰吉凶,仅地支名称)⭐ V3 新增
- 季节养生(饮食/运动/作息)
### 第 3 页:穿衣 + 科普 + 故事
- **今日穿衣建议**(幸运色/忌讳色)⭐ V3 新增
- 黄历科普(天干地支/冲煞/吉神凶神)
- 传统故事(与节气或日期相关)
- 启示总结
---
## ⚠️ 注意事项
1. **字体版权**: 使用系统自带字体(如黑体),避免版权风险
2. **内容准确性**: 黄历数据需核对权威来源
3. **免责声明**: 必须包含"传统文化 仅供参考"
4. **文件大小**: 控制在 250KB 以内,便于网络传播
5. **备份脚本**: 保存生成脚本以便复用
---
## 🔧 脚本说明
### generate_almanac.py(整合脚本)
```bash
# 使用方法
python scripts/generate_almanac.py --date 2026-04-08
# 参数说明
--date: 日期(YYYY-MM-DD 格式)
--pages: 生成页数(1/2/3,默认 3)
--output: 输出目录(默认 reports/)
```
### 核心函数
```python
def draw_centered_text(draw, text, y, font, color):
"""居中绘制文字"""
bbox = draw.textbbox((0, 0), text, font=font)
text_width = bbox[2] - bbox[0]
x = (WIDTH - text_width) // 2
draw.text((x, y), text, fill=color, font=font)
return y + (bbox[3] - bbox[1])
def draw_double_border(draw, width, height):
"""绘制双层边框"""
draw.rectangle([10, 10, width-10, height-10],
outline='#8B0000', width=8)
draw.rectangle([22, 22, width-22, height-22],
outline='#D4AF37', width=2)
```
---
## 📊 质量标准
### 视觉标准
- 双层边框完整(外红内金)
- 所有文字居中对齐
- 字体大小符合标准
- 颜色使用正确
- 行间距舒适(不拥挤)
- 分隔线位置合理
- 底部信息完整
- 无错别字
- 文件大小 150-250KB
- 图片清晰无锯齿
### 内容标准
- 日期信息准确(公历 + 农历 + 干支)
- 宜忌内容完整
- 生肖运势正确(红榜/黑榜各 3 个)
- 财神方位准确
- **吉时查询准确**(12 时辰吉凶)⭐ V3 新增
- **穿衣建议准确**(五行颜色)⭐ V3 新增
- 养生建议合理
- 科普内容准确
- 故事内容完整
- 底部免责声明存在
---
## 📚 参考文档
- [almanac-image-standard.md](references/almanac-image-standard.md) - 完整黄历图片制作标准 V3
- [lunar-python-api-guide.md](references/lunar-python-api-guide.md) - lunar-python API 使用规范(Solar vs Lunar)⭐ V3.0.2 新增
- [almanac-data-template.md](references/almanac-data-template.md) - 黄历数据模板
- [publish-guide.md](references/publish-guide.md) - 发布平台指南
---
## 📝 版本历史
| 版本 | 日期 | 改进内容 |
|------|------|----------|
| V1 | 2026-04-07 18:27 | 初始版本(单页 1080x1920) |
| V1-Full | 2026-04-07 18:33 | 完整版(3 页 1080x1920) |
| V1-Opt | 2026-04-07 18:39 | 优化版(3 页 1080x1280) |
| V2 | 2026-04-07 18:42 | 最终版(3 页 1080x1400) |
| Skill | 2026-04-08 11:23 | 技能化封装 |
| **V2.0.0** | **2026-04-09 15:25** | **紧凑版 + 干支 + 吉时 + 穿衣** ⭐ |
| **V2.2.0** | **2026-04-10 23:50** | **5 套模板 + lunar-python + 24 节气** ⭐⭐⭐ |
| **V2.3.0** | **2026-04-11 18:53** | **大字体优化(可读性 +15%)** ⭐⭐⭐⭐⭐ |
| **V2.3.1** | **2026-04-11 19:30** | **季节故事修复(不再春季贴秋膘)** ⭐⭐⭐⭐⭐ |
| **V3.0.1** | **2026-04-12** | **通用化版(lunar-python 干支修复)** ⭐⭐⭐⭐⭐ |
| **V3.0.2** | **2026-05-22** | **lunar-python API 修复(Solar.fromYmd vs Lunar.fromYmd)** ⭐⭐⭐⭐⭐ |
---
*最后更新:2026-05-22 09:55*
*数字化专班 - 商业航天数字化转型*
don't have the plugin yet? install it then click "run inline in claude" again.