Install
openclaw skills install almanac-creatorDaily 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)
openclaw skills install almanac-creator标准版本: almanac-image-standard.md V3
适用范围: 每日黄历图片生成
输出规格: 3 页 PNG 图片(1080x1400 像素)
最新版本: V3.0.3 抖音优化版(2026-04-18)
本技能用于按照标准化流程制作每日黄历图片(V3 紧凑版),包含:
适用于今日头条(三图轮播)、抖音/小红书(单图发布)等平台。
抖音算法适配优化:
紧急修复: 干支计算错误(月柱/日柱)
| 更新项 | 说明 |
|---|---|
| 🔧 月柱修复 | 根据节气计算月柱(修复 lunar-python 农历月问题) |
| 🔧 日柱修复 | 使用 Solar.fromYmd 转换(修复 Lunar.fromYmd 农历日期问题) |
| ✅ 向后兼容 | 完全兼容 V3.0.1,建议所有用户升级 |
问题说明:
Lunar.fromYmd() 导致日期转换错误getMonthInGanZhi() 返回农历月干支,不是节气月干支紧急修复: 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 日"Solar.fromYmd().getLunar() 正确转换教训: lunar-python 的 API 命名容易混淆,公历→农历一律用 Solar.fromYmd().getLunar()
使用示例:
# 单日生成
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
| 更新项 | 说明 |
|---|---|
| ✅ 字体全面加大 | 栏目题 55→60px,正文 45→48px,故事/养生正文 40→44px |
| ✅ 行间距优化 | 1.3→1.4,提升阅读舒适度 |
| ✅ 间距调整 | 栏目/内容/分隔线间距加大 2-3px |
| ✅ 可读性提升 | 整体可读性提升约 15%,中老年用户友好 |
| ✅ 无需分页 | 保持 3 页完整布局,内容不裁剪 |
| 更新项 | 说明 |
|---|---|
| ✅ 集成 lunar-python | 使用 lunar-python(lunar-java 的 Python 版本) |
| ✅ 干支计算升级 | 使用 lunar-python 准确计算(替代 100+ 行映射表) |
| ✅ 宜忌准确性提升 | 使用 lunar-python 传统算法(替代本地池) |
| ✅ 5 套模板轮换 | 传统/现代/喜庆/典雅/清新,每日自动轮换 |
| ✅ 24 节气故事 | 故事池从 4 个扩展到 24 个(按季节分类) |
| ✅ 输出目录修复 | 支持多用户、跨平台,智能路径检测 |
| ✅ 生肖黑榜修复 | 智能检测重复,确保红黑榜无冲突 |
| ✅ 传统元素支持 | 彭祖百忌、纳音、星宿、建除十二值星、九星 |
| ✅ 代码优化 | 减少 150+ 行硬编码,更易维护 |
| 更新项 | 说明 |
|---|---|
| ✅ 生肖运势 | 基于六合三合相冲相害计算,吉凶正确 |
| ✅ 吉时查询 | 使用十二神值时(青龙明堂等) |
| ✅ 财神方位 | 根据日干准确计算方位 |
| 更新项 | 说明 |
|---|---|
| ✅ 紧凑布局 | 全局段间距离缩小 10-15px |
| ✅ 完整干支 | 第 1 页增加年柱 + 月柱 + 日柱 |
| ✅ 吉时查询 | 第 2 页增加时辰吉凶(仅地支名称) |
| ✅ 穿衣建议 | 第 3 页增加五行颜色搭配 |
| 参数 | 值 | 说明 |
|---|---|---|
| 宽度 | 1080 像素 | 适配手机竖屏 |
| 高度 | 1400 像素 | 内容舒展不拥挤 |
| 比例 | 9:12.96 | 接近 9:13 竖版 |
| 格式 | PNG | 高质量无损压缩 |
| 质量 | 95 | 平衡文件大小与质量 |
| 文件大小 | 150-250 KB/页 | 适合网络传播 |
# 背景色
BACKGROUND_COLOR = '#F8F0E6' # 温暖的米黄色(宣纸质感)
# 双层边框
外层边框:8px 中国红 (#8B0000)
内层边框:2px 金色 (#D4AF37)
边距:外层 10px,内层 22px
| 用途 | 字号 | 颜色 | 示例 |
|---|---|---|---|
| 主标题 | 90px | #8B0000 | 每日黄历 |
| 副标题 | 65px | #2C2C2C | 2026 年 4 月 8 日 星期三 |
| 栏目题 | 55px | #8B0000 | 今日宜/生肖运势 |
| 正文 | 45px | #2C2C2C | 宜忌内容 |
| 小字 | 38px | #999999 | 底部信息 |
# 优先使用 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 | 底部信息、辅助说明 |
获取当日黄历信息:
数据来源:
https://api.qingyunke.com/api.php?key=free&appid=01&msg=今日黄历使用脚本生成 3 页图片:
# 方法 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
视觉检查清单:
内容检查清单:
今日头条文案:
标题:【{日期}】{农历} 每日黄历
正文:
今日黄历已更新!
📅 公历:{日期}
🌙 农历:{农历}
✅ 宜:{宜内容}
❌ 忌:{忌内容}
🏆 红榜:{红榜生肖}
⚠️ 黑榜:{黑榜生肖}
更多详情见图👆
#每日黄历 #传统文化 #生肖运势
抖音/小红书文案:
【{日期}黄历】{节气信息}✨
今日红榜生肖:{红榜}
黑榜生肖:{黑榜}
财神在{财神方位},记得朝这个方向求财哦💰
#黄历 #每日运势 #传统文化
| 平台 | 发布时间 | 使用图片 | 文案 |
|---|---|---|---|
| 今日头条 | 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
# 使用方法
python scripts/generate_almanac.py --date 2026-04-08
# 参数说明
--date: 日期(YYYY-MM-DD 格式)
--pages: 生成页数(1/2/3,默认 3)
--output: 输出目录(默认 reports/)
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)
| 版本 | 日期 | 改进内容 |
|---|---|---|
| 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
数字化专班 - 商业航天数字化转型