# 是否存在完整的诊断结果，而且是只有一个病人的病历
prompt_judge_one_patient_and_diagnosis = """你负责根据提供的临床记录，判断是否满足以下条件：
1. 是一份病历，并且只关于一个病人
2. 文本中明确提出了病人的最终诊断结果，而且诊断结果需要有充分的信心，不能是猜测的

如果满足上述条件，请将完整的诊断结果翻译并重写为“中文+英文”的标准格式，放入 <answer> 标签中。示例输出：<answer>脂肪栓塞综合征（Fat Embolism Syndrome）</answer>
如果不满足以上2个条件，输出<answer>None</answer>


临床记录如下：
<medical_record>
{}
</medical_record>


先给出逐步的分析，然后按要求输出结果。
"""

# 病历是否覆盖3个阶段
prompt_coverage_3_stages = """你负责根据提供的临床记录，判断是否同时具有下面3个阶段的信息：
1. 病史采集（包括主诉、现病史等）
2. 体格检查
3. 辅助检查

如果满足，输出<answer>yes</answer>
如果不满足，输出<answer>no</answer>


临床记录如下：
<medical_record>
{}
</medical_record>


先给出逐步的分析，然后按要求输出结果。
"""

# 提取核心诊断+完整诊断
prompt_get_full_diagnosis = """你是一名资深的临床医学专家。你的任务是仔细阅读并分析下面提供的医学病例文本，然后提取并总结出病人的**中文**最终诊断结果。

请严格按照以下两个部分来组织你的回答：

**1. 核心诊断**
*   这应该是最简洁、最官方的疾病名称
*   请直接引用或用最精炼的医学术语给出，**使用中文**

**2. 完整诊断**
*   这部分需要你综合全文信息，形成一段逻辑连贯、全面的诊断性描述。这部分是一份出院小结中的诊断概要，需要清晰地勾勒出病人的整体情况。**使用中文**。
*   你的描述中需要包含以下关键要素：
    *   **a. 病因:** 明确指出导致疾病的直接病原体，以及根本的、促成的危险因素（例如，生活习惯、既往病史等）。
    *   **b. 核心疾病:** 再次陈述核心诊断名称，将其置于整个病理过程的中心。
    *   **c. 主要并发症:** 列出由核心疾病直接引发的最重要的并发症和伴随疾病
    *   **d. 关键病理生理状态:** 描述这些并发症导致的身体功能异常状态

你的目标是生成一份既准确又全面的诊断摘要，能够让其他医生快速掌握病情的全貌。


输出格式
[逐步的分析过程]
<核心诊断>
翻译为中文的核心诊断
</核心诊断>
<完整诊断>
翻译为中文的完整诊断
</完整诊断>


输出示例
[逐步的分析过程]
...
<核心诊断>
慢性真菌性脑膜炎
</核心诊断>
<完整诊断>
由静脉注射毒品导致的白色念珠菌血行播散，所引发的慢性真菌性脑膜炎；并继发严重的梗阻性脑积水、颅内高压及多发性颅神经功能障碍。
</完整诊断>


注意，如果文本中不存在明确的诊断信息，或者诊断结果是不确定的，或者文本中描述了多个病人的诊断结果，则输出
<核心诊断>None</核心诊断>
<完整诊断>None</完整诊断>


待分析的医学文本如下：
{}


请你给出逐步的分析，最后按照格式输出中文的**核心诊断**和**完整诊断**。
"""


prompt_judge_enough_data = """你是一名专业医生，你的任务是严格、客观地评估一份给定的【临床记录】，判断其中包含的证据是否足以从逻辑上推理出【待评估的诊断】。

【待评估的诊断】
<Diagnosis>
{}
</Diagnosis>


临床记录如下：
<medical_record>
{}
</medical_record>


## 请严格按照以下步骤进行思考和输出

1. **信息提取**：首先，仔细阅读并拆解【临床记录】（病历），识别出所有与诊断相关的关键阳性体征、阴性体征、症状描述、检查结果等。

2. **支持性证据分析**：
    *   列出病历中**所有支持**【【待评估的诊断】的证据。
    *   对于每一条证据，简要说明它为什么支持该诊断（例如：“高热和咳嗽是肺炎的典型症状”、“X光片显示肺部浸润影，是肺炎的直接影像学证据”）。

3. **不支持/矛盾/缺失证据分析**：
    *   列出病历中**所有与【待评估的诊断】不符或相矛盾**的证据。
    *   识别并列出为了得到诊断，通常**需要但临床记录中缺失**的关键信息（例如：“要诊断心肌梗死，但病历中缺失心肌酶谱和心电图结果”）。

4. **综合评估与结论**：
    *   基于以上分析，综合权衡支持性证据与不支持/矛盾/缺失的证据。
    *   做出最终判断：临床记录是否足以支持诊断？

5. 最终输出：
- 如果记录足以支持诊断，回复：<answer>yes</answer>
- 如果记录不足以支持诊断，回复：<answer>no</answer>

先给出思考过程，然后输出结果。
"""

# 病史采集
prompt_HPI = """你是一位顶尖的临床信息学专家，你的任务是从一份临床记录中，提取并结构化“在某一特定时间点上，医生通过问诊所能获得的全部信息”，并将结果翻译为中文。

## 核心任务与时间节点定义
所有信息提取必须严格基于定义的“关键时间快照”：患者因当前不适前来就诊，在医生完成了口头交流（问诊）之后，且在医生开始实施任何新的物理检查（体格检查）或开具任何新的辅助检查项目之前。
该时间节点必须满足：
1. **存在多个时间段的检查结果时**
   如果记录中明确包含不同时间段的检查信息（例如：外院检查 vs 本院检查，或本院历史检查 vs 近期检查），则时间节点至少早于最后一次检查。

2. **所有检查处于同一时间段时**
   如果记录中所有检查均在同一时间段完成（例如患者为初诊，无既往外院或本院历史检查记录），则时间节点定义在这一系列检查之前。
   

总之，在这个时间点之前，患者刚被医生口头问诊；在此之后，患者进行了若干检查，然后才确定了最终诊断。


## 信息提取类别与格式
请提取以下八个类别的信息，确保每个类别的值都是一个单独的**中文**字符串。

1.  基本信息: 整合患者的性别、年龄、职业等基本人口学信息。格式形如“性别：女\n年龄：20岁\n职业：学生”
2.  主诉: 简洁地概括患者本次就诊最主要的原因，通常包括核心症状和持续时间。
3.  现病史: 描述疾病的起病、演变、症状特征、伴随症状，以及期间是否用药和效果。
4.  既往史: 汇总患者的既往疾病、手术外伤、过敏、传染病及疫苗接种史。
5.  用药史: 记录患者当前长期服用或近期正在使用的所有药物及保健品。
6.  个人史: 汇总患者的烟酒史、职业与特殊物质接触史、婚育史、近期旅行史及饮食生活习惯。
7.  家族史: 描述患者直系亲属及近亲的健康状况，尤其是有无遗传病或类似疾病史。
8.  历史诊疗记录: 整合患者在本次就诊前获得的有帮助的资料，包括之前在外院和之前在本院的检查结果和治疗情况；如果之前的诊断结果恰好是正确诊断，则历史诊疗中不得包含该诊断。不得出现具体的医院名称。

## 处理总则
1.  时间点过滤:
    必须包含患者口述的所有历史，以及患者随身带来的所有外院诊疗资料。
    严格排除所有在本次就诊于本院产生的信息，包括本院的体格检查发现和所有辅助检查结果。
2.  专业化改写: 所有内容必须使用完整、标准的中文医学术语重新组织。必须扩展所有医学缩写，确保表述清晰、无歧义。
3.  默认值处理原则:
    若原始记录中完全未提及某项具体信息，则视为该项无异常或不存在，并应在输出中明确表述。例如，如果未提及过敏史，则输出应包含“无过敏史”；如果未提及生活习惯，则输出应包含“无特殊生活习惯”。
4.  时间点的改写
    不得包含绝对的时间，例如“2019年10月”；如果不得不记录时间，需要转化为相对时间，例如“半年前”。
5.  **禁止在任何地方提及病人的最终诊断结果**；如果在历史诊疗记录中某个怀疑的诊断恰好是正确诊断，也需要进行剔除。


## 输出要求
生成一个JSON对象。

## 输出示例
```json
{{
  "基本信息": "性别：男\n年龄：70岁\n职业：未知",
  "主诉": "双手无力3年，双下肢无力2年，双手肌肉萎缩1年。",
  "现病史": "患者于3年前无明显诱因出现双手无力，呈逐渐缓慢加重趋势，在长时间持物时无力感及手抖表现明显。2年前，患者出现双下肢僵硬无力感，多在劳累后发生，并伴有腰部无力及颈部不适，主要表现为颈部后转费力。上述症状持续加重。1年前，患者发现双手“虎口”及背部肌肉出现萎缩，并自述能肉眼观察到双上肢肌肉跳动。近1年，双上肢无力及颈部不适感显著加重，表现为抬头困难，双上肢无法高举，穿脱衣物困难，上楼梯费力。同时出现日间安静状态下的轻度憋气感，夜间需使用呼吸机辅助呼吸。期间曾根据外院建议接受治疗，效果不佳。",
  "既往史": "既往体健，明确否认高血压、冠心病、糖尿病病史。无手术外伤史，无过敏史，无传染病史，无疫苗接种史。",
  "用药史": "无。",
  "个人史": "无吸烟及饮酒史。明确否认毒物、粉尘、放射性物质接触史。已婚，育有2子1女。无近期旅行史。无特殊饮食生活习惯。",
  "家族史": "父母已故。母亲生前有类似症状，于66岁因心力衰竭去世，但未获明确诊断。患者有一位妹妹身体健康，一位弟弟及一位表姐有类似症状。其子女均身体健康。",
  "历史诊疗记录": "诊断方面：曾多次在外院被诊断为“颈椎管狭窄”和“神经根型颈椎病”，后被疑诊为“肯尼迪病可能”。检查方面：外院肌电图检查提示“广泛神经源性损害”；外院颈椎MRI影像检查可见C4至C6椎间盘突出及椎管狭窄。治疗方面：曾接受过“营养神经”治疗，但症状无明显缓解。"
}}
```


临床记录如下：
<medical_record>
{}
</medical_record>


先给出逐步的分析，然后按格式输出JSON结果。
"""


# 诊断难度等级
prompt_difficulty_level = """你是一位资深临床医生，需要根据提供的病历内容，评估该病例的临床诊断难度等级。请严格遵循以下评估标准：

### 诊断难度分级标准

**Level 1 (Extremely Easy)**
- **信息收集**：主诉明确（例如“咽喉痛伴发热”），患者描述清晰，常规检查即可确诊（例如咽拭子）。
- **诊断难度**：症状与检查结果高度典型（例如急性咽炎），无需或仅需简单鉴别。

**Level 2 (Moderately Easy)**
- **信息收集**：主诉需追问细节（例如腹痛部位/性质），需基础检查（例如血常规、超声）。
- **诊断难度**：可能指向2-3种常见病（例如胃炎 vs 胆囊炎），通过简单排除法确诊。

**Level 3 (Moderate)**
- **信息收集**：主诉模糊（例如“乏力”），需针对性检查（例如甲状腺功能、铁代谢）。
- **诊断难度**：症状与检查结果交叉（例如自身免疫病 vs 感染），需结合病史排除非典型表现。

**Level 4 (Difficult)**
- **信息收集**：主诉与病因关联低（例如头痛实为颅内肿瘤），需特殊检查（例如MRI、活检）。
- **诊断难度**：症状罕见或矛盾（例如副肿瘤综合征），需多学科会诊或长期随访。

**Level 5 (Extremely Difficult)**
- **信息收集**：患者症状和检查结果无法正确确诊，依赖高成本/高风险检查（例如全外显子测序）。
- **诊断难度**：多系统受累且机制不明（例如罕见遗传病），需国际共识或前沿研究支持。

### **分级应用场景**
- Level 1-2：基层医疗机构常见病（如上呼吸道感染、高血压）
- Level 3：综合医院门诊多数病例（如糖尿病并发症、早期肿瘤）
- Level 4-5：三级医院疑难病例（如罕见病、多系统疾病）


分级结果放在<answer></answer>中，格式例如：<answer>Level 3 (Moderate)</answer>



病历如下：
<medical_record>
{}
</medical_record>



现在请根据信息收集难度和诊断难度两方面开始评估，先给出分析过程，最后给出分级结果。"""


# 根据协和的科室分布，设计的分类prompt
SYSTEM_prompt_department_class = """你是一位专业医疗AI助手，请根据病人描述信息，判断该病人对应的科室是否可以是某个给定的科室？

请你判断，并结果放入<answer>标签中。
如果可以分类到该科室，回答<answer>Yes</answer>
否则回答<answer>No</answer>
"""

USER_prompt_department_class = """病人的描述信息如下：
{}


请你分析该病人对应的科室是否可以是{}?
请将结果放入<answer>标签中。
"""

department_list = [
    "全科医学科（普通内科）",
    "心内科",
    "呼吸与危重症医学科",
    "消化内科",
    "肾内科",
    "血液内科",
    "风湿免疫科",
    "感染内科",
    "肿瘤内科",
    "内科重症监护室（MICU）",
    "老年医学科",
    "内分泌科",
    "重症医学科（ICU）",
    "儿科",
    "神经科",
    "心理医学科",
    "皮肤科",
    "变态（过敏）反应科",
    "急诊科",
    "中医科",
    "康复医学科",
    "临床营养科",
    "罕见病医学科",
    "基本外科",
    "骨科",
    "心外科",
    "胸外科",
    "泌尿外科",
    "神经外科",
    "血管外科",
    "整形美容外科",
    "乳腺外科",
    "肝脏外科",
    "麻醉科",
    "妇产科",
    "眼科",
    "耳鼻喉科",
    "口腔科",
]

# 提取出病人的第一句话，通常比主诉的内容更多
prompt_rewrite_Zhusu = """根据以下病人就诊时医生通过多轮对话记录下的病历信息：
{}


请还原病人在就诊时，是如何向医生描述自己就诊的原因的。
注意，当时医生通过多轮问诊才收集到这么多信息，你需要判断病人最开始向医生表达的是什么，而不是复述病历的全部信息。
至少需要把病人最近感受很直接、很关键、很重要的信息都说明，例如重大的手术、最近很严重的症状等。


输出格式：
逐步的分析...
<answer>
病人的表达，是第一人称、口语化的一段文字，不要分段；表述需要合理。
</answer>


先给出逐步的分析，然后将结果放进<answer>标签内。
"""
# prompt_rewrite_Zhusu = """你是一位语言风格模仿专家和医疗场景模拟器。
# 你的任务是：将一份书面、规范的线上问诊病历“主诉”，转化为一句病人见到医生时，最可能说的第一句话，并将这句话放入 `<answer>` 标签中。

# **请严格遵守以下要求：**

# 1.  **身份与口吻：** 绝对要符合普通病人的身份，使用非常生活化、口语化的语言，就像在和医生当面聊天，禁止包含括号。
# 2.  **避免专业术语：** 将主诉中的医学术语或书面语（如“上眼眶”、“反复发作”、“持续性”）替换为日常用语（如“眼睛上面这块儿”、“老是这样”、“一直”）。
# 3.  **聚焦核心问题：** 病人的第一句话不必主诉里的所有细节（比如持续的时间）。
# 4.  **儿童交流：** 8岁及以下的孩子，应由家长代为陈述，例如：“我家孩子这几天一直发烧。”；对于其他情况，必须是病人自己陈述。


# ### 示例：

# 输入：性别：男\n年龄：7岁\n职业：学龄前儿童\n主诉：乏力、纳差一周
# 输出：<answer>我家孩子他说感到浑身没劲儿，也吃不下东西</answer>

# 现在，请转化下面的主诉：
# 输入:{}
# 输出:
# """


prompt_all_examination = """你是一位临床信息提取专家，你的任务是从一段给定的医疗相关文本中，精准提取特定的检查信息，并翻译为中文。

## 提取类别
1.  体格检查: 医生通过视、触、叩、听等物理方法获得的关于患者身体状况的发现。
2.  辅助检查: 包括但不限于实验室检查、病理学检查、影像学检查（如MRI, CT）、电生理检查（如肌电图）、基因检测等所有非体格检查的客观检测结果。

## 处理规则
1.  全面搜寻并提取文本中所有符合范围的检查结果，确保无遗漏。
2.  将所有提取内容翻译为流畅、专业的中文。可以保留国际通用的医学术语缩写（如CT, MRI, DNA）。
3.  保留所有关键细节；对于具体的数值，需要**额外标注**结果是否异常的描述或符号（如↑, ↓）；如果数值正常，标注（正常）。
4.  若某一类别（体格检查或辅助检查）在文本中完全没有提及，则对应的值应为空字符串 `""`。
5.  若某项检查没有明确的结果，则剔除掉。例如，去掉“头部CT如图所示”、“白细胞如表1所示”这种模糊表述。
6.  如果某一项检查进行了多次，则需要进行合理的合并或取舍，例如保留最严重的一次结果，或者将几次结果进行综合。
7.  需要隐藏所有关于检查时间和医疗机构的信息，确保最终结果看起来像一次独立的检测

## 输出要求
输出一个包含“体格检查”和“辅助检查”两个键的JSON对象。

## 输出示例
```json
{{
    "体格检查": "体温36.6°C，血压154/90 mmHg（升高），脉搏76次/分，呼吸频率18次/分，呼吸环境空气时血氧饱和度98%。身高157.5 cm，体重34 kg，体重指数（BMI）13.7（偏低）。右侧前额可见瘀斑和愈合的裂伤。患者存在感受性失语，严重限制了她对口头语言的理解能力，但能理解书面或打印的问题。她警觉、互动良好，对人、地点和时间有定向力。言语流畅，无错语症。能轻松执行简单和复杂指令。注意力和集中力完好。除瞳孔不等大外（左瞳孔直径5 mm，右瞳孔直径3 mm），颅神经检查未见异常。双侧瞳孔对光反射存在。肌肉体积减少，但肌张力和肌力正常。感觉、深腱反射和小脑功能测试结果正常。",
    "辅助检查": "头部MRI（3T扫描+增强）：显示双侧颞叶T2-FLAIR序列高信号，延伸至顶叶前部，伴岛叶下区域强化及岛叶皮层扩散受限。磁共振波谱分析显示左颞叶病灶区及侧脑室内乳酸峰显著升高（提示代谢障碍，尤其是线粒体疾病）。\n\n实验室检查：\n- 血乳酸水平2.6 mmol/L（参考值0.5-2.0 mmol/L，轻度升高↑）\n- 血红蛋白11.3 g/dL（参考值12.0-16.0，偏低↓）\n- 电解质、血糖、肝肾功能、血常规其余指标均正常\n\n脑脊液检查：葡萄糖和蛋白水平升高，细胞计数正常；单纯疱疹病毒DNA阴性。\n\n脑电图：弥漫性减慢，无癫痫样放电。\n\n肌肉活检：\n- 苏木精-伊红染色显示肌纤维大小不一，偶见萎缩纤维\n- Gomori三色染色可见红色不规则亚肌膜物质（破碎红纤维）\n- 细胞色素C氧化酶/琥珀酸脱氢酶联合染色显示散在蓝色COX缺陷纤维\n- 电镜见亚肌膜区大量线粒体聚集伴嵴结构异常\n\n基因检测：线粒体DNA m.3243A→G致病性变异（76%异质性）"
}}
```



医疗文本如下：
<medical_record>
{}
</medical_record>


先给出逐步的分析，然后按格式输出JSON结果。
"""

USER_prompt_all = """待处理文本：
{}
"""


SYSTEM_prompt_classify = """你作为专业医疗文书处理助手，需将输入文本的全部内容严格分类至以下指定类别中：
{}

**任务要求**：
1. **内容完整性**
   - 提取原文所有检查结果（包括数值、单位及异常标记如↑↓→）
   - 保留原始术语表述，禁止修改或省略任何医疗细节

2. **动态分类规则**
   - 每个预定义类别对应输出JSON的一个键
   - 键名严格使用给定的类别名称，包括空格、括号、标点都要完全照抄
   - 值内容为对应分类文本的字符串；如果语句不完整，需要补全成为一个完整的语句

3. **输出规范**
   - 仅当某类别存在有效内容时才保留键值对；如果不包含某个类别的内容，则直接去掉对应的键值对。
   - 最终输出必须是标准JSON格式（{{"字段1":"值1", "字段2":"值2", ...}}）
   - 先给出逐步的分析，然后JSON结果置于<answer></answer>标签内

4. **分类优先级**
   - 在多个类别可能适用的情况下，请优先匹配靠前的类别
   - 只有在所有其他类别均不适用时，才归类到“其他”类别

**示例输出**
[逐步的分析]
<answer>
JSON内容
</answer>
"""


SYSTEM_prompt_get_item_name = """你是一个专业的医疗报告分析专家，请根据报告内容生成标准化的检查项目组合名称。按照以下要求处理：

1. **提取检查项目**：
   - 找出报告中所有检查项目
   - 将口语化表述转为标准名称（如："验血"→"血常规"）
   - 忽略症状描述、正常值等无关内容
   - 如果检查项目太多，可以使用更宽泛的检查名称；最多3个检查名称

2. **生成规则**：
   - 有检查项目时：
     • 用"-"连接
     • 例："血常规-肝功能-心电图"
   
   - 无检查项目时：
     • 只返回"None"

3. **输出格式**：
   - 例：<answer>血常规-尿常规</answer>
   - 或：<answer>None</answer>


先给出逐步的分析，然后将结果放入<answer>标签中。
"""


SYSTEM_prompt_makeup_results = """你负责基于真实病历数据，为指定的体格检查项目生成模拟结果。
指定的项目可能是未记录在病历中的，也可能是未进行的，你需要基于病历进行合理的编造，给出模拟的检查结果。

核心要求：
1. 严格对应 - 输出JSON的键名必须与输入项目名称完全一致（包括标点、括号等特殊字符）
2. 客观描述 - 结果需使用确定性表述，禁止使用"可能"、"或许"等推测性词语
3. 无诊断暗示 - 禁止包含任何疾病诊断表述（如"符合XX症状"、"提示XX疾病"）
4. 禁止生成形如“无记录”、“未知”、“未测量”、“未记录”等结果

输出格式：
逐步的分析...
<answer>
{
   "检查项目A": "具体结果描述",
   "检查项目B": "具体结果描述",
   ...
}
</answer>
"""

USER_prompt_makeup_results = """请根据以下病历信息生成模拟检查结果：

<病历>
{}
</病历>


【需生成结果的检查项目（一行对应一个完整的检查项目）】
{}


先给出逐步的分析，然后根据指定的格式输出生成的JSON。
"""

prompt_makeup_physical_exam = """你负责基于真实病历数据，为指定的体格检查项目生成模拟结果。
指定的项目可能是未记录在病历中的，也可能是未进行的，你需要基于病历进行合理的编造，给出模拟的检查结果。

## 核心要求：
1. 客观描述 - 结果需使用确定性表述，禁止使用"可能"、"或许"等推测性词语
2. 无诊断暗示 - 禁止包含任何疾病诊断表述（如"符合XX症状"、"提示XX疾病"）
3. 禁止生成形如“无记录”、“未知”、“未测量”、“未记录”等结果
4. 允许拒绝检查：当检查面向某个特定人群，而病历中的患者不属于该群体时，输出“该患者不适合进行这个检查。”。例如，患者是20岁男性，那么就不适合进行妇产科、儿科、老年人的专项检查。

## 输出格式：
逐步的分析...
<answer>
检查项目A: "具体结果描述"
检查项目B: "具体结果描述"
...
</answer>

## 输出示例
...
<answer>
腹部视诊: 腹部轻度膨隆，右下腹可见阑尾切除手术瘢痕，右髂部可见髋关节置换术瘢痕，未见胃肠型及蠕动波。
腹部触诊: 全腹轻度弥漫性压痛，以中下腹为著，无局限性肌紧张及反跳痛，未触及明确包块。
儿科（发育指标及常见异常筛查）: 该患者不适合进行这个检查。
</answer>



请根据以下病历信息生成模拟检查结果：

<病历>
{}
</病历>


【需生成结果的检查项目（一行对应一个完整的检查项目）】
{}


先给出逐步的分析，然后根据指定的格式输出检查结果。
"""


SYSTEM_prompt_check_WanZheng = """你是一个医学数据质量审核专家，请严格按规则判断检查结果是否完整：

1. 判断标准：答案必须包含明确医学结果信息，例如包含下面任意一种：
   - 数值（如120g/L）
   - 状态（阴性/阳性/正常/异常）
   - 具体描述（如"无细菌生长"）
   - 结论性术语（升高/降低/阳性等）

2. 以下情况视为"不完整"：
   - 仅重复检查名称（如"维生素B12"）
   - 仅说明检测行为（如"进行了培养"）
   - 模糊描述（如"已检测"）

3. 输出要求：
   - 完整 → <answer>Yes</answer>
   - 不完整 → <answer>No</answer>
   - 仅输出XML标签，无任何额外文本
"""

USER_prompt_check_WanZheng = """检查项目名称：{}

需要分析的检查结果：{}

请你分析检查结果是否包含明确的医学信息（例如数值/状态/描述/结论），结果放入<answer>标签中。
"""

SYSTEM_prompt_extract_item_result = """你是一个医学信息提取专家，请严格按规则操作：

1. 任务：从原文提取指定检查的明确结果
2. 提取标准：
   - 必须包含医学关键信息（数值/状态/病原体描述等）
   - 去除冗余短语（如"检测显示"）
   - 保持原始医学术语
   - 最终得到一句完整的话，例如“胸部CT检查结果无异常”，或者“白细胞计数偏高”

3. 输出要求：
   - 找到结果 → <answer>[一句完整的话描述具体的结果]</answer>
   - 未找到 → <answer>None</answer>
   - 仅输出XML标签
"""

USER_prompt_extract_item_result = """检查项目名称：{}

原文：
{}

请你分析原文是否包含对应检查项目的检查结果，并将结果放入<answer>标签中。
"""


prompt_get_necessary_physical_groups = """你是一位资深的临床医学AI助手，具备丰富的临床诊断和体格检查知识。
你负责分析病人的“部分病历”，然后从**体格检查项目索引**中，推理出该病人有必要进行的若干体格检查项目类别。

**输出要求**
- 只输出所选检查项目类别的名称（即索引中的 "key"），并放入<answer>标签中
- 每个类别名称单独占一行
- 禁止添加编号、解释等任何其他无关文本

**输出示例**
[逐步的分析过程]
...
<answer>
浅表淋巴结检查（头颈/腋窝/腹股沟淋巴结等）
腹部检查（包含肝脾等检查）
运动系统检查（肌力、肌张力及异常运动观察）
</answer>

**病人的部分病历**
<问诊病史>
{}
</问诊病史>
<诊断>
{}
</诊断>


**体格检查项目索引**
<体检索引>
{}
</体检索引>


请你先给出逐步的分析，然后按格式输出病人有必要进行的若干体格检查项目类别。
"""


prompt_judge_misdiagnosis_strict = """你是一名专业医生，负责根据提供的病历，判断病人是否经历了误诊，并提取出做出诊断的医生身份。

**判断标准：**
病人必须**首先由一位医生根据已有的辅助检查结果得出明确诊断，但该诊断事后被证实为错误**；随后，**该诊断被另一位医生推翻，并基于进一步检查或评估，给出了新的、正确的最终诊断**。  
此外，**在误诊发生时，必须已经进行了相关的辅助检查**，而医生仍做出了错误判断；之后可能通过补充检查，由另一位医生纠正原诊断并确立正确诊断。

**注意，以下几种情况不算误诊：**
1.  **诊断细化**：从一个宽泛的诊断到一个具体的子类诊断（例如：从“肺炎”到“支原体肺炎”），不属于误诊
2.  **初步怀疑**：初步诊断只是怀疑可能是某种疾病，并未据此进行治疗，则不属于误诊
3.  **无辅助检查**：如果没有经过**明确记录**的辅助检查，得到了错误的诊断，则不属于误诊


**医生身份：**
如果存在误诊，需要分别提取做出错误诊断、做出最终诊断的医生身份；如果没有**明确记录**医生的身份，则输出None


**输出格式要求:先给出逐步的分析，然后输出误诊的诊断，并输出误诊医生的身份 和 做出最终正确诊断的医生身份，如下所示**
[逐步的分析过程]
<answer>
误诊的诊断名词（中文）；如果没有误诊，则填写None
误诊医生的身份类别（如：地方医院医生、全科医生、急诊科医生、住院医师等；若无法确定则填写 None）
最终正确诊断医生的身份类别（如：上级医院医生、专科医生、主任医师、专家会诊组等；若无法确定则填写 None）
</answer>


**输出格式示例1:**
...
<answer>
急性阑尾炎
None
专家会诊组
</answer>


**输出格式示例2:**
...
<answer>
None
None
None
</answer>


**病历如下:**
<病历>
{}
</病历>



请你先给出逐步的分析，然后按格式输出病人是否经历了误诊。
"""


prompt_get_location = """你是一名专业的数据分析员，负责从提供的病历中，提取出病历的位置信息。

**提取标准：**
你需要从病历文本中识别并提取出与地理位置相关的信息。这个位置可以是国家，也可以具体到省份、州、城市等。

**注意，以下情况需要特别处理：**
1.  **多个地点：** 如果病历中提到多个地点（例如，患者籍贯、现居住地、就诊医院所在地、旅行史），请优先提取**就诊医院**或**出具病历机构**所在的地点，其次是患者籍贯、现居住地，最后是旅行史。
2.  **无明确地点：** 如果病历中没有明确提及任何地理位置，请输出“None”
3.  **语言多样性：** 地点可能以中文、英文或其他语言出现，请最终翻译并输出中文地点

**输出格式要求: 先给出逐步的分析，然后只输出提取出的最具体的位置信息，如下所示**
[逐步的分析过程]
<answer>
国家|州、省份等详细信息
</answer>

注意，`州、省份等详细信息`如果未能提取到，则可以不输出


**输出格式示例1:**
...
<answer>
中国|北京
</answer>


**输出格式示例2:**
...
<answer>
美国
</answer>

**输出格式示例3:**
...
<answer>
None
</answer>


**病历如下:**
<病历>
{}
</病历>



请你先给出逐步的分析，然后按格式输出位置信息。
"""


prompt_classify_research_department = """# 角色与任务定义
你将扮演一个专业的AI医疗分诊助手。你的核心任务是分析患者提供的病历信息，为他们推荐一个最适合进行详细问诊和最终诊断的临床科室。
注意，不考虑去哪个科室治疗，只考虑哪个科室的医生可以完成诊断过程。

# 科室分配规则
你必须严格遵循以下规则和步骤进行判断：

### 第一步：检查强制分配至“其他”的特殊情况
在分析具体病情前，首先检查是否存在以下任一情况。如果满足，必须直接将患者分配到 **“其他：原因”** 科室，并停止后续分析：
1.  **儿童患者**：患者年龄为14岁及以下。由于可用科室列表不包含“儿科”，因此输出“其他：儿科”。
2.  **无法获取有效病史**：患者因严重的精神障碍、意识模糊、失语等原因，无法进行有效的沟通和交流，输出“其他：无法沟通”。

### 第二步：进行常规科室匹配
如果患者不满足以上任何特殊情况，请根据其核心病症和诊断，从以下列表中选择 **一个最匹配** 的科室，这个科室的医生需要对病人进行详细问诊、开具检查单和做出最终诊断：

**可选科室列表：**
[{}]

### 第三步：处理无法匹配的情况
如果在上述列表中找不到合适的科室来对应患者的病情，则将其分配到 **“其他：对应的科室名称”**，例如“其他：遗传科”。


# 输入信息
**病历信息**:
<病历>
{}
</病历>


# 输出格式要求
[逐步的分析]
<answer>
科室名称
</answer>


# 输出示例
...(逐步的分析)
<answer>
其他：儿科
</answer>


请你先给出逐步的分析，然后将结果输出到<answer>标签内。
"""


prompt_verify_quality = """你是一名专业医生，负责判断病历的质量是否合格。


## 判断标准
一份质量合格的病历，需要满足：
1. 只记录了一位病人，不能把多个病人的信息写到同一份病历中
2. 最终诊断必须明确，不能模糊不清
3. 最终诊断需要有明确的依据和支持（**金标准检查结果**），确保诊断是准确的
4. 检查结果不能与最终诊断存在明显的矛盾


如果质量合格，输出<answer>yes</answer>；否则，输出<answer>no</answer>。

## 输出格式要求
[逐步的分析]
<answer>yes / no</answer>

## 输出示例
...(逐步的分析)
<answer>yes</answer>


病历内容如下：
<病历>
{}
</病历>


请你先给出逐步的分析，然后将结果输出到<answer>标签内。
"""


prompt_makeup_HPI = """你是一名医学专家，负责基于一份不完整的病历，撰写专业、连贯的“现病史”。

**任务**
根据完整病历（含主诉、现病史、检查结果、诊断等），分析、补全并重写“现病史”。

**执行步骤**
1. **全面分析**：仔细阅读病历，关注主诉、诊断、体格及辅助检查
2. **识别缺失**：对比现有现病史与诊断，根据该疾病的典型临床表现，找出当前“现病史”中**很可能**遗漏的关键阳性症状或体征
3. **循证推断**：只补充病历中有强证据支持、极可能出现的症状

**关键原则**
- **一致性**：补充内容必须与病历其他部分完全一致
- **保守性**：仅添加极高可能性的症状，避免过度推测
- **保留有效信息**：尽量保留原始现病史中不冲突的内容
- **隐秘性**：禁止包含最终诊断结果
- **确定性**：最终的现病史，不得包含不确定的结果，例如“未提及发热”、“腹痛未知”、“可能呕吐”等

**输出格式**
```text
...[逐步的分析过程]
<answer>
[最终生成的现病史]
</answer>
```

**病历如下：**
<病历>
{}
</病历>


请先给出逐步的分析，然后按格式将现病史输出到<answer>标签内。
"""
