优化简历定制简历生产

This commit is contained in:
zk
2026-04-29 20:22:08 +08:00
parent 4909ae6076
commit afc782da16
3 changed files with 67 additions and 43 deletions
+14 -7
View File
@@ -5,6 +5,7 @@
"""
import asyncio
import time
from langchain_core.output_parsers import StrOutputParser
from langchain_core.prompts import ChatPromptTemplate
@@ -44,20 +45,23 @@ async def analyze_skill_gap(skill_tags: list[str], resume_json: str) -> list[str
_summary_optimize_chain = (
ChatPromptTemplate.from_messages([("system", SUMMARY_OPTIMIZE_PROMPT), ("human", "请开始优化。")])
| LLM.JIAYU_CLAUDE_SONNET_4_5.create(temperature=0.3)
| LLM.DOUBAO_PRO_32K.create(temperature=0.3)
| StrOutputParser()
)
async def optimize_summary(job_title: str, add_skills: list[str], original_summary: str) -> str:
"""优化个人概述,融入技能关键词"""
t0 = time.monotonic()
try:
return await _summary_optimize_chain.ainvoke({
result = await _summary_optimize_chain.ainvoke({
"job_title": job_title, "add_skills": "".join(add_skills) if add_skills else "",
"original_summary": original_summary or "暂无",
})
log.info(f"AI优化summary完成 ({round(time.monotonic() - t0, 2)}s)")
return result
except Exception as e:
log.warning(f"AI优化summary失败: {e}")
log.warning(f"AI优化summary失败: {e} ({round(time.monotonic() - t0, 2)}s)")
return original_summary
@@ -65,21 +69,24 @@ async def optimize_summary(job_title: str, add_skills: list[str], original_summa
_experience_optimize_chain = (
ChatPromptTemplate.from_messages([("system", EXPERIENCE_OPTIMIZE_PROMPT), ("human", "请开始优化。")])
| LLM.JIAYU_CLAUDE_SONNET_4_5.create(temperature=0.3)
| LLM.DOUBAO_PRO_32K.create(temperature=0.3)
| StrOutputParser()
)
async def optimize_module(job_title: str, job_description: str, module_data: str) -> list | dict | None:
"""优化子表模块经历描述,返回修改后的完整模块数据"""
"""优化单条经历描述,返回修改后的记录数据"""
t0 = time.monotonic()
try:
raw = await _experience_optimize_chain.ainvoke({
"job_title": job_title, "job_description": job_description or "",
"original_module_data": module_data,
})
return parse_llm_json(raw)
result = parse_llm_json(raw)
log.info(f"AI优化经历模块完成 ({round(time.monotonic() - t0, 2)}s)")
return result
except Exception as e:
log.warning(f"AI优化经历模块失败: {e}")
log.warning(f"AI优化经历模块失败: {e} ({round(time.monotonic() - t0, 2)}s)")
return None
+3 -3
View File
@@ -36,13 +36,13 @@ SUMMARY_OPTIMIZE_PROMPT = """你是一个简历优化助手。根据目标岗位
4. 避免过度优化,改动越少越好
5. 直接输出优化后的文本,不要其他内容"""
EXPERIENCE_OPTIMIZE_PROMPT = """你是一个简历优化助手。根据目标岗位信息,微调用户的经历描述。
EXPERIENCE_OPTIMIZE_PROMPT = """你是一个简历优化助手。根据目标岗位信息,微调用户的一条经历描述。
【目标岗位】
{job_title}
{job_description}
【原始经历数据】
【原始经历数据(单条记录)
{original_module_data}
规则:
@@ -50,7 +50,7 @@ EXPERIENCE_OPTIMIZE_PROMPT = """你是一个简历优化助手。根据目标岗
2. 让描述更贴合目标岗位方向,但不要编造内容
3. 避免过度优化,改动越少越好
4. description 字段是 [{{"id": "xxx", "text": "xxx"}}] 格式:修改时保留原 id 只改 text,新增段落生成随机8位字符串作为 id,删除段落直接移除
5. 返回修改后的完整模块数据JSON 格式,与输入格式一致)"""
5. 返回修改后的单条记录JSON 对象格式,与输入格式一致,不要包裹在数组中"""
AGENT_PLAN_PROMPT = """你是一个简历编辑助手。你的唯一职责是根据用户指令修改简历内容。