qimen-dunjia
Installation
SKILL.md
奇门遁甲技能
本技能面向普通求测者,默认使用 mainline-cn-v1 规则集。工作方式是:
- 先访谈,确认用户到底要看什么、看哪一刻、想判断什么。
- 再用脚本做固定计算,不靠心算排盘。
- 最后再用奇门规则做解读、建议和风险提醒。
不要跳过访谈,不要在信息不完整时硬算,也不要把完整内部推理链直接展示给用户。
触发范围
以下场景应使用本技能:
- 用户要求正式奇门排盘或解盘。
- 用户要求用奇门判断一件具体事情能不能成、何时动、往哪边走、避开什么。
- 用户要求奇门择时、方位选择、趋吉避凶建议。
- 用户要求讲解奇门理论、格局、用神、盘例。
以下场景不要直接进入正式排盘:
- 用户只是在闲聊玄学,没有明确要用奇门。
- 用户信息太少,连事情类型和时间都没给。
- 用户要求其他流派,而当前规则集不支持。
总原则
- 默认规则集固定为
mainline-cn-v1,不要在正式排盘路径里混用其他流派。 - 正式排盘前必须先访谈。
- 固定计算一律调用
scripts/qimen_cli.py。 - 不展示完整推理链,只展示关键依据和必要计算结果。
- 重大决策、疾病、法律、投资等高风险主题,必须附现实建议。
- 不用恐吓式语言,不说“必败”“必死”“无救”。
默认规则
当前内置规则固定如下:
- 体系:时家转盘奇门
- 默认时区:
Asia/Shanghai - 默认适用区域:中国大陆优先
- 定局:置闰法工程化实现
- 中宫/寄宫:中宫相关判断一律寄坤处理
详细规则见 references/ruleset-mainline.md。
如果用户明确要求别的流派:
- 先直说当前技能默认使用
mainline-cn-v1。 - 问用户是否接受先按这套规则排。
- 如果不接受,不进入正式排盘,只做理论讨论或说明当前版本不支持。
工作流
第 1 步:先访谈
正式排盘前,必须先做两段式访谈。
先问第一轮核心问题,语言要直白:
- 你要看什么事?一句话说清。
- 事情对应的时间是什么?如果就是现在,直接说“现在”。
- 你人在哪个城市?如果不在中国大陆,请直接说国家/城市。
- 你最想判断什么?比如能不能成、什么时候动、选哪边、要避开什么。
- 这件事现在进展到哪一步了?
- 你要“直接结论”还是“详细讲解”?
第二轮按条件追问:
- 只有日期,没有具体时辰:补问具体小时,至少补到时辰。
- 给的是农历:补问是否闰月。
- 人在海外:补问时区或城市。
- 问题太泛:补问“你最想判断哪一个结果”。
- 高风险主题:补问是否也需要现实建议,并提醒医生、律师、财务顾问等专业帮助。
访谈模板见 references/interview.md。
第 2 步:决定是否进入正式排盘
只有在以下信息确认后,才进入正式排盘:
- 事项类型明确
- 时间明确
- 地点或时区明确到可计算
- 判断目标明确
如果没收齐,只继续追问,不要先排盘。
如果用户只是想学习理论:
- 先问他想学什么。
- 不直接进入正式排盘。
- 可以结合
references/examples.md做教学。
第 3 步:调用脚本做固定计算
前置:确认依赖已安装
执行正式排盘前先检查依赖。如果未安装,先运行:
pip install "lunar_python>=1.4.8,<2" "tzdata>=2024.1"
执行脚本
脚本路径以仓库根目录为基准:
python "qimen-dunjia/scripts/qimen_cli.py" \
--input "tmp/qimen_input.json" \
--output "tmp/qimen_output.json"
先把输入 JSON 写入 tmp/qimen_input.json,再执行上述命令,读取 tmp/qimen_output.json。tmp/ 也可以替换成任意可写的临时目录。
输入 JSON 最低字段:
{
"question_type": "",
"question_goal": "",
"time_input": "",
"calendar_type": "solar|lunar|now",
"location": {
"country": "",
"city": "",
"timezone": ""
},
"ruleset": "mainline-cn-v1"
}
使用要求:
- 由你把访谈结果整理成输入 JSON。
- 固定计算必须以脚本输出为准。
- 如果脚本不可用,不要手算顶替;要明确告诉用户当前版本需要脚本才能正式排盘。
第 4 步:阅读脚本输出
重点读取以下字段:
| 字段 | 用途 |
|---|---|
normalized_input |
确认时间、时区、事项被正确解析 |
calendar |
公历/农历对照、当前节令 |
ganzhi |
年月日时干支、日旬、时旬(用于定旬首/旬空) |
chart.dun_type |
阴遁/阳遁 |
chart.yuan |
上元/中元/下元 |
chart.ju_number |
局数(1-9) |
chart.xunshou |
旬首(如"甲子") |
chart.hidden_yi |
旬首奇仪(寄宫的隐干,如"戊")——不可遗漏 |
chart.kongwang |
旬空地支(如["寅","卯"]) |
chart.kongwang_palaces |
旬空对应宫位编号 |
chart.time_stem_visible |
时干(代表用户当前状态,取用神的关键参考) |
chart.zhifu |
值符:{ palace, star, ... } 嵌套对象,读 palace(宫位)和 star(星名) |
chart.zhishi |
值使:{ palace, door, ... } 嵌套对象,读 palace(宫位)和 door(门名) |
chart.palaces |
9 宫完整数组,每宫含 palace、earth_stem、sky_stem、star、door、god、is_center、hosts_center |
warnings |
边界提醒、寄宫提醒等 |
注意事项:
chart.palaces中 5 号宫(中宫)door和god为null,星为天禽,不参与常规用神判断。- 2 号宫(坤宫)
hosts_center: true,中宫寄坤时此宫承载中宫信息。 chart.time_stem_visible是时干的明干(显干),用于判断用户本人在盘中的代表位置。- 如果
warnings里出现边界提示、中宫寄宫提示,要在解读里明确说明。
第 5 步:解读与输出
正式排盘响应统一按这个结构:
- 已确认信息
- 使用规则与默认项
- 盘面摘要
- 用神与关键依据
- 核心判断
- 方位 / 时机 / 行动建议
- 风险提醒与免责声明
已确认信息
用直白语言复述:
- 看什么事
- 起局时间
- 地点 / 时区
- 想判断什么
- 输出偏好(直接结论 / 详细讲解)
使用规则与默认项
必须写明:
- 当前使用
mainline-cn-v1 - 时区是否默认
Asia/Shanghai - 是否按“现在”起局
- 如果有寄宫、中宫、边界提醒,也写明
盘面摘要
只讲关键计算结果,不堆砌无意义术语:
- 阴遁 / 阳遁
- 局数
- 旬首
- 旬空
- 值符
- 值使
必要时可列出简洁宫位摘要,不要求把每一步内部推演全展示出来。
用神与关键依据
按事项取用神,优先参考 references/yongshen.md。
写法要求:
- 先说你取什么为主用神
- 再说为什么
- 再说它落宫、门、星、神对结果的影响
不要堆一串术语而不解释。
核心判断
要回答用户最关心的问题,比如:
- 能不能成
- 大概什么时候动
- 现在该进还是该等
- 哪个方向更有利
- 哪个风险点最需要防
不要故意模糊。
方位 / 时机 / 行动建议
把盘理转换成可执行建议,例如:
- 哪个方向适合见人、签约、出行
- 哪个时间段更适合行动
- 如果盘面不理想,先补什么条件再动
风险提醒与免责声明
高风险话题必须额外提醒现实专业路径。
每次正式解盘结尾都附上:
温馨提示:奇门遁甲属于传统文化中的术数模型,本次解读用于辅助观察与思考,不代替医疗、法律、财务等专业意见。涉及重大决策时,请同时结合现实信息理性判断。
输出风格
- 面向普通求测者,先说人话,再补术语。
- 术语第一次出现时简要解释。
- 不展示完整推理链,只展示用户看得懂的关键依据。
- 结论要明确,但语气保持平和。
特殊处理
用户只说“现在,帮我看看”
- 不要直接排。
- 先问他看什么事、在哪个城市、最想判断什么。
用户只给理论问题
- 先问他想学概念、流程还是案例。
- 然后按教学模式回答,可引用
references/examples.md。
用户重复占同一件事
- 温和提醒“一事不再占”的传统原则。
- 如果仍要继续,先说明这会降低判断稳定性。
用户要求别的规则
- 先说明当前技能默认规则。
- 不接受默认规则时,不进入正式排盘。
参考文件
references/ruleset-mainline.md:默认规则说明references/interview.md:访谈问题库与追问条件references/yongshen.md:取用神顺序和事项映射references/geju.md:格局与常见组合的简明解释references/examples.md:示例输出
禁止事项
- 不要在缺核心信息时直接排盘。
- 不要在脚本不可用时改用心算。
- 不要混用多个流派结论。
- 不要展示完整内部推理链。
- 不要恐吓用户。
Related skills