Tuchuanhuhuhu commited on
Commit
69554cc
·
1 Parent(s): 9aaabb1

上传文件时自动总结

Browse files
ChuanhuChatbot.py CHANGED
@@ -334,7 +334,7 @@ with gr.Blocks(css=customCSS, theme=small_and_beautiful_theme) as demo:
334
  submitBtn.click(**transfer_input_args).then(**chatgpt_predict_args, api_name="predict").then(**end_outputing_args)
335
  submitBtn.click(**get_usage_args)
336
 
337
- index_files.change(handle_file_upload, [current_model, index_files, chatbot], [index_files, chatbot, status_display])
338
 
339
  emptyBtn.click(
340
  reset,
 
334
  submitBtn.click(**transfer_input_args).then(**chatgpt_predict_args, api_name="predict").then(**end_outputing_args)
335
  submitBtn.click(**get_usage_args)
336
 
337
+ index_files.change(handle_file_upload, [current_model, index_files, chatbot, language_select_dropdown], [index_files, chatbot, status_display])
338
 
339
  emptyBtn.click(
340
  reset,
locale/en_US.json CHANGED
@@ -70,5 +70,7 @@
70
  "您的IP区域:未知。": "Your IP region: Unknown.",
71
  "获取IP地理位置失败。原因:": "Failed to get IP location. Reason: ",
72
  "。你仍然可以使用聊天功能。": ". You can still use the chat function.",
73
- "您的IP区域:": "Your IP region: "
 
 
74
  }
 
70
  "您的IP区域:未知。": "Your IP region: Unknown.",
71
  "获取IP地理位置失败。原因:": "Failed to get IP location. Reason: ",
72
  "。你仍然可以使用聊天功能。": ". You can still use the chat function.",
73
+ "您的IP区域:": "Your IP region: ",
74
+ "总结": "Summarize",
75
+ "生成内容总结中……": "Generating content summary..."
76
  }
locale/ja_JP.json CHANGED
@@ -70,5 +70,7 @@
70
  "您的IP区域:未知。": "あなたのIPアドレス地域:不明",
71
  "获取IP地理位置失败。原因:": "IPアドレス地域の取得に失敗しました。理由:",
72
  "。你仍然可以使用聊天功能。": "。あなたはまだチャット機能を使用できます。",
73
- "您的IP区域:": "あなたのIPアドレス地域:"
 
 
74
  }
 
70
  "您的IP区域:未知。": "あなたのIPアドレス地域:不明",
71
  "获取IP地理位置失败。原因:": "IPアドレス地域の取得に失敗しました。理由:",
72
  "。你仍然可以使用聊天功能。": "。あなたはまだチャット機能を使用できます。",
73
+ "您的IP区域:": "あなたのIPアドレス地域:",
74
+ "总结": "要約する",
75
+ "生成内容总结中……": "コンテンツ概要を生成しています..."
76
  }
modules/models/base_model.py CHANGED
@@ -178,12 +178,27 @@ class BaseLLMModel:
178
  status_text = self.token_message()
179
  return chatbot, status_text
180
 
181
- def handle_file_upload(self, files, chatbot):
182
  """if the model accepts multi modal input, implement this function"""
183
  status = gr.Markdown.update()
184
  if files:
185
- construct_index(self.api_key, file_src=files)
186
- status = "索引构建完成"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
187
  return gr.Files.update(), chatbot, status
188
 
189
  def prepare_inputs(self, real_inputs, use_websearch, files, reply_language, chatbot):
 
178
  status_text = self.token_message()
179
  return chatbot, status_text
180
 
181
+ def handle_file_upload(self, files, chatbot, language):
182
  """if the model accepts multi modal input, implement this function"""
183
  status = gr.Markdown.update()
184
  if files:
185
+ index = construct_index(self.api_key, file_src=files)
186
+ status = i18n("索引构建完成")
187
+ # Summarize the document
188
+ logging.info(i18n("生成内容总结中……"))
189
+ os.environ["OPENAI_API_KEY"] = self.api_key
190
+ from langchain.chains.summarize import load_summarize_chain
191
+ from langchain.prompts import PromptTemplate
192
+ from langchain.chat_models import ChatOpenAI
193
+ from langchain.callbacks import StdOutCallbackHandler
194
+ prompt_template = "Write a concise summary of the following:\n\n{text}\n\nCONCISE SUMMARY IN " + language + ":"
195
+ PROMPT = PromptTemplate(template=prompt_template, input_variables=["text"])
196
+ handler = StdOutCallbackHandler()
197
+ llm = ChatOpenAI(callbacks=[handler])
198
+ chain = load_summarize_chain(llm, chain_type="map_reduce", return_intermediate_steps=True, map_prompt=PROMPT, combine_prompt=PROMPT)
199
+ summary = chain({"input_documents": list(index.docstore.__dict__["_dict"].values())}, return_only_outputs=True)["output_text"]
200
+ print(i18n("总结") + f": {summary}")
201
+ chatbot.append([i18n("总结"), summary])
202
  return gr.Files.update(), chatbot, status
203
 
204
  def prepare_inputs(self, real_inputs, use_websearch, files, reply_language, chatbot):
modules/models/models.py CHANGED
@@ -494,7 +494,7 @@ class XMChat(BaseLLMModel):
494
  limited_context = False
495
  return limited_context, fake_inputs, display_append, real_inputs, chatbot
496
 
497
- def handle_file_upload(self, files, chatbot):
498
  """if the model accepts multi modal input, implement this function"""
499
  if files:
500
  for file in files:
 
494
  limited_context = False
495
  return limited_context, fake_inputs, display_append, real_inputs, chatbot
496
 
497
+ def handle_file_upload(self, files, chatbot, language):
498
  """if the model accepts multi modal input, implement this function"""
499
  if files:
500
  for file in files: