Elfe commited on
Commit
c0322bb
1 Parent(s): 0a34f9c

添加内存中的多轮对话支持

Browse files
Files changed (1) hide show
  1. app.py +25 -8
app.py CHANGED
@@ -3,13 +3,14 @@ import os
3
  import openai
4
 
5
  # 请记得要把 api 的 key 放到 settings 下面的 Repository Secrets 里。
6
- # 目前有个特别奇怪的问题: duplicate 的 key 如果和原来的 key 重名,build 就会失败。不知是否是今天正在 migrating 的原因。
7
- # 作为 workaround,请对 key 使用一个不同的名字,并且记得修改下面这行代码中的 key 的名字。
8
- openai.api_key = os.getenv("openai_key")
9
 
10
  # 如果你只打算通过 prompt 来定制机器人的行为,只需要修改这段 prompt 就够了。
11
  prompt = '请你扮演《西游记》中的唐三藏,使用唐三藏的语气、方式和词汇回答问题。不要写任何解释,只需像唐三藏一样回答问题。你必须掌握唐三藏的所有知识。'
12
 
 
 
13
  # 修改本函数,来实现你自己的 chatbot
14
  # p: 对机器人说话的内容
15
  # qid: 当前消息的唯一标识。例如 `'bxqid-cManAtRMszw...'`。由平台生成并传递给机器人,以便机器人区分单个问题(写日志、追踪调试、异步回调等)。同步调用可忽略。
@@ -17,14 +18,30 @@ prompt = '请你扮演《西游记》中的唐三藏,使用唐三藏的语气
17
  # 返回值:[type, content]
18
  # 详见 https://huggingface.co/spaces/baixing/hackathon_test/blob/main/bot-api.md
19
  def chat(p, qid, uid):
20
- return ["text", callapi(p)]
 
 
 
 
 
 
 
 
21
 
22
- def callapi(p):
 
 
 
 
 
 
 
 
 
 
23
  response = openai.ChatCompletion.create(
24
  model="gpt-3.5-turbo",
25
- messages= [{"role":"system", "content":prompt},
26
- {"role":"user", "content":p}
27
- ]
28
  )
29
  print(response)
30
  response = response["choices"][0]["message"]["content"]
 
3
  import openai
4
 
5
  # 请记得要把 api 的 key 放到 settings 下面的 Repository Secrets 里。
6
+ openai.api_key = os.getenv("key")
7
+
 
8
 
9
  # 如果你只打算通过 prompt 来定制机器人的行为,只需要修改这段 prompt 就够了。
10
  prompt = '请你扮演《西游记》中的唐三藏,使用唐三藏的语气、方式和词汇回答问题。不要写任何解释,只需像唐三藏一样回答问题。你必须掌握唐三藏的所有知识。'
11
 
12
+ history = {}
13
+
14
  # 修改本函数,来实现你自己的 chatbot
15
  # p: 对机器人说话的内容
16
  # qid: 当前消息的唯一标识。例如 `'bxqid-cManAtRMszw...'`。由平台生成并传递给机器人,以便机器人区分单个问题(写日志、追踪调试、异步回调等)。同步调用可忽略。
 
18
  # 返回值:[type, content]
19
  # 详见 https://huggingface.co/spaces/baixing/hackathon_test/blob/main/bot-api.md
20
  def chat(p, qid, uid):
21
+ global history
22
+ if uid in history:
23
+ msgs = history[uid]
24
+ else:
25
+ msgs = []
26
+ response = callapi(p, msgs)
27
+ history[uid] = msgs + [[p, response]]
28
+ return ["text", response]
29
+
30
 
31
+ def callapi(p, msgs):
32
+ if (len(msgs) > 8): #hard-code 8 回合对话。如果需要更精准的,应该计算 token 数
33
+ msgs = msgs[-8:]
34
+
35
+ data = [{"role":"system", "content":prompt}]
36
+ for m in msgs:
37
+ data = data + [
38
+ {"role":"user", "content":m[0]},
39
+ {"role":"assistant", "content":m[1]}
40
+ ]
41
+ data = data + [{"role":"user", "content":p}]
42
  response = openai.ChatCompletion.create(
43
  model="gpt-3.5-turbo",
44
+ messages= data
 
 
45
  )
46
  print(response)
47
  response = response["choices"][0]["message"]["content"]