Heyyaha commited on
Commit
12a01f5
·
verified ·
1 Parent(s): 3624f08

Update app.py

Browse files
Files changed (1) hide show
  1. app.py +99 -0
app.py CHANGED
@@ -0,0 +1,99 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ import gradio as gr
2
+ import os
3
+ from datetime import datetime
4
+ from gradio_client import Client
5
+ import re
6
+ import uuid
7
+ import json
8
+
9
+ # 初始化任务生成客户端(改为 Qwen 模型)
10
+ taskgen_client = Client("Qwen/QwQ-32B-Demo")
11
+
12
+ OUTPUT_DIR = "outputs"
13
+ os.makedirs(OUTPUT_DIR, exist_ok=True)
14
+
15
+ # 拆解 JD 成任务
16
+ def extract_task_from_jd(jd):
17
+ message = f"""你是一个岗位分析助手,请根据以下JD内容提取一个可以用来测试候选人核心能力的具体任务。
18
+ 请以如下格式回复:
19
+ 任务:(任务描述)
20
+
21
+ JD: {jd}"""
22
+ response = taskgen_client.predict(sender_value=message, api_name="/submit")
23
+ return response.strip()
24
+
25
+ # 基于任务生成三个解决方案
26
+ def generate_solutions_from_task(task):
27
+ message = f"""你是一个解决方案生成助手,请根据以下任务设计三种不同的实现思路。
28
+ 请严格按如下格式输出:
29
+ 方案1:(内容)
30
+ 方案2:(内容)
31
+ 方案3:(内容)
32
+
33
+ 任务: {task}"""
34
+ response = taskgen_client.predict(sender_value=message, api_name="/submit")
35
+ solutions = re.findall(r"方案[123][::]\s*(.*)", response)
36
+ if len(solutions) < 3:
37
+ return response.strip(), "(解析失败,显示原始回复)", ""
38
+ s1 = solutions[0].strip()
39
+ s2 = solutions[1].strip()
40
+ s3 = solutions[2].strip()
41
+ return s1, s2, s3
42
+
43
+ # 构建 Gradio UI
44
+ def build_ui():
45
+ with gr.Blocks() as demo:
46
+ gr.Markdown("## 📌 JD 任务拆解 + 解决方案选择 Demo")
47
+
48
+ jd_input = gr.Textbox(label="输入 JD", placeholder="请输入岗位描述 JD")
49
+ task_output = gr.Textbox(label="拆解出的测试任务", lines=2, interactive=False)
50
+ generate_task_btn = gr.Button("🧠 拆解 JD 成任务")
51
+
52
+ generate_solutions_btn = gr.Button("🚀 基于任务生成三个方案")
53
+ sol1 = gr.Textbox(label="方案1 / 或原始回复", lines=10, interactive=False)
54
+ sol2 = gr.Textbox(label="方案2", lines=10, interactive=False)
55
+ sol3 = gr.Textbox(label="方案3", lines=10, interactive=False)
56
+
57
+ select_radio = gr.Radio(choices=["1", "2", "3"], label="请选择你最满意的解决方案编号")
58
+
59
+ comment = gr.Textbox(lines=4, label="📝 请对选择的方案填写选择理由或批注该方案的优缺点")
60
+ user_solution = gr.Textbox(lines=6, label="📄 填写你自己的解决方案(可选)")
61
+
62
+ submit = gr.Button("✅ 提交 RLHF 数据")
63
+ feedback = gr.Textbox(label="系统反馈", interactive=False)
64
+
65
+ task_state = gr.State()
66
+
67
+ def handle_task_gen(jd_text):
68
+ task = extract_task_from_jd(jd_text)
69
+ return task, task
70
+
71
+ def handle_solutions_gen(task_text):
72
+ s1, s2, s3 = generate_solutions_from_task(task_text)
73
+ return s1, s2, s3
74
+
75
+ def handle_submit(selected_idx, user_input_text, comment_text, task_text):
76
+ record = {
77
+ "task": task_text,
78
+ "selected_index": selected_idx,
79
+ "user_solution": user_input_text,
80
+ "comment": comment_text,
81
+ "timestamp": datetime.now().isoformat()
82
+ }
83
+ try:
84
+ with open("rlhf_jd_data.jsonl", "a", encoding="utf-8") as f:
85
+ json.dump(record, f, ensure_ascii=False)
86
+ f.write("\n")
87
+ return f"✅ 数据已保存,选择方案 {selected_idx}"
88
+ except Exception as e:
89
+ return f"❌ 保存失败:{str(e)}"
90
+
91
+ generate_task_btn.click(fn=handle_task_gen, inputs=[jd_input], outputs=[task_output, task_state])
92
+ generate_solutions_btn.click(fn=handle_solutions_gen, inputs=[task_state], outputs=[sol1, sol2, sol3])
93
+ submit.click(fn=handle_submit, inputs=[select_radio, user_solution, comment, task_state], outputs=[feedback])
94
+
95
+ return demo
96
+
97
+ if __name__ == "__main__":
98
+ demo = build_ui()
99
+ demo.launch()