Spaces:
Running
Running
import gradio as gr | |
import os | |
from datetime import datetime | |
from gradio_client import Client | |
import re | |
import uuid | |
import json | |
# 初始化任务生成客户端(腾讯混元 Space) | |
taskgen_client = Client("tencent/Hunyuan-Large") | |
OUTPUT_DIR = "outputs" | |
os.makedirs(OUTPUT_DIR, exist_ok=True) | |
# 拆解 JD 成任务 | |
def extract_task_from_jd(jd): | |
message = f"""你是一个岗位分析助手,请根据以下JD内容提取一个可以用来测试候选人核心能力的具体任务。 | |
请确保任务具有一定的技术深度,特别是在编程、算法设计、系统架构或其他技术方面的能力。 | |
任务的描述需要清晰且具体,能够考察候选人对于该岗位要求的核心技能。 | |
请以如下格式回复: | |
任务:(任务描述) | |
JD: {jd}""" | |
response = taskgen_client.predict(message=message, api_name="/chat") | |
return response.strip() # 直接返回原始响应内容,便于调试 | |
# 基于任务生成三个解决方案 | |
def generate_solutions_from_task(task): | |
message = f"""你是一个解决方案生成助手,请根据以下任务设计三种不同的实现思路。 | |
每个方案需要包含详细的步骤,具体的操作流程,并在每个步骤中提供执行细节。请确保每个方案的字数不少于200字,并且要包含以下内容: | |
1. 总体思路:解决方案的总体思路与背景。 | |
2. 执行步骤:实现该方案的详细步骤,最好分步操作,字数要求至少50字。 | |
3. 技术栈:使用的具体技术、工具、框架和技术栈。 | |
4. 代码示例(如果适用):相关技术实现的代码片段。 | |
5. 挑战与解决方案:在实现过程中可能遇到的技术难题以及相应的解决方法。 | |
请严格按如下格式输出,每个方案应包含详细信息,字数不少于200字: | |
方案1: | |
1. 总体思路: (简述方案的总体设计思想) | |
2. 执行步骤: (具体的实现步骤,最好有分步) | |
3. 技术栈: (技术栈、工具、框架) | |
4. 代码示例: (如果适用,提供相关代码片段) | |
5. 挑战与解决方案: (在实现过程中可能遇到的问题和解决方法) | |
方案2: | |
1. 总体思路: (简述方案的总体设计思想) | |
2. 执行步骤: (具体的实现步骤,最好有分步) | |
3. 技术栈: (技术栈、工具、框架) | |
4. 代码示例: (如果适用,提供相关代码片段) | |
5. 挑战与解决方案: (在实现过程中可能遇到的问题和解决方法) | |
方案3: | |
1. 总体思路: (简述方案的总体设计思想) | |
2. 执行步骤: (具体的实现步骤,最好有分步) | |
3. 技术栈: (技术栈、工具、框架) | |
4. 代码示例: (如果适用,提供相关代码片段) | |
5. 挑战与解决方案: (在实现过程中可能遇到的问题和解决方法) | |
任务: {task}""" | |
response = taskgen_client.predict(message=message, api_name="/chat") | |
# 提取方案的详细内容 | |
solutions = re.findall(r"方案[123][::]\s*(.*?)(?=\n|方案[123][::]|$)", response, re.DOTALL) | |
if len(solutions) < 3: | |
return response.strip(), "(解析失败,显示原始回复)", "" | |
s1 = solutions[0].strip() | |
s2 = solutions[1].strip() | |
s3 = solutions[2].strip() | |
return s1, s2, s3 | |
# 构建 Gradio UI | |
def build_ui(): | |
with gr.Blocks() as demo: | |
gr.Markdown("## 📌 JD 任务拆解 + 解决方案选择 Demo") | |
jd_input = gr.Textbox(label="输入 JD", placeholder="请输入岗位描述 JD") | |
task_output = gr.Textbox(label="拆解出的测试任务", lines=2, interactive=False) | |
generate_task_btn = gr.Button("🧠 拆解 JD 成任务") | |
generate_solutions_btn = gr.Button("🚀 基于任务生成三个方案") | |
sol1 = gr.Textbox(label="方案1 / 或原始回复", lines=10, interactive=False) | |
sol2 = gr.Textbox(label="方案2", lines=10, interactive=False) | |
sol3 = gr.Textbox(label="方案3", lines=10, interactive=False) | |
select_radio = gr.Radio(choices=["1", "2", "3"], label="请选择你最满意的解决方案编号") | |
comment = gr.Textbox(lines=4, label="📝 请对选择的方案填写选择理由或批注该方案的优缺点") | |
user_solution = gr.Textbox(lines=6, label="📄 填写你自己的解决方案(可选)") | |
submit = gr.Button("✅ 提交 RLHF 数据") | |
feedback = gr.Textbox(label="系统反馈", interactive=False) | |
task_state = gr.State() | |
def handle_task_gen(jd_text): | |
task = extract_task_from_jd(jd_text) | |
return task, task | |
def handle_solutions_gen(task_text): | |
s1, s2, s3 = generate_solutions_from_task(task_text) | |
return s1, s2, s3 | |
def handle_submit(selected_idx, user_input_text, comment_text, task_text): | |
record = { | |
"task": task_text, | |
"selected_index": selected_idx, | |
"user_solution": user_input_text, | |
"comment": comment_text, | |
"timestamp": datetime.now().isoformat() | |
} | |
try: | |
with open("rlhf_jd_data.jsonl", "a", encoding="utf-8") as f: | |
json.dump(record, f, ensure_ascii=False) | |
f.write("\n") | |
return f"✅ 数据已保存,选择方案 {selected_idx}" | |
except Exception as e: | |
return f"❌ 保存失败:{str(e)}" | |
generate_task_btn.click(fn=handle_task_gen, inputs=[jd_input], outputs=[task_output, task_state]) | |
generate_solutions_btn.click(fn=handle_solutions_gen, inputs=[task_state], outputs=[sol1, sol2, sol3]) | |
submit.click(fn=handle_submit, inputs=[select_radio, user_solution, comment, task_state], outputs=[feedback]) | |
return demo | |
if __name__ == "__main__": | |
demo = build_ui() | |
demo.launch() | |