From dbbc7d891c0f9837d3580842fa5326ba40a21476 Mon Sep 17 00:00:00 2001 From: zhaoqingang <zhaoqg0118@163.com> Date: 星期四, 21 十一月 2024 11:46:20 +0800 Subject: [PATCH] 出题组卷 --- app/api/chat.py | 84 +++++++++++++++++++++++++++-------------- 1 files changed, 55 insertions(+), 29 deletions(-) diff --git a/app/api/chat.py b/app/api/chat.py index 5e6f1da..de05de8 100644 --- a/app/api/chat.py +++ b/app/api/chat.py @@ -200,6 +200,7 @@ pass elif agent_type == AgentType.BASIC: try: + service = BasicService(base_url=settings.basic_base_url) while True: # 鎺ユ敹鍓嶇娑堟伅 message = await websocket.receive_json() @@ -213,36 +214,61 @@ if not question: await websocket.send_json({"message": "Invalid request", "type": "error"}) continue - - service = BasicService(base_url=settings.basic_base_url) - async for result in service.excel_talk(question, chat_id): - try: - if result[:5] == "data:": - # 濡傛灉鏄紝鍒欐埅鍙栨帀鍓�5涓瓧绗︼紝骞跺幓闄ら灏剧┖鐧界 - text = result[5:].strip() - else: - # 鍚﹀垯锛屼繚鎸佸師鏍� - text = result + if agent.agent_type == "questionTalk": + async for result in service.questions_talk(question, chat_id): try: - data = json.loads(text) - output = data.get("output", "") - excel_name = data.get("excel_name", "") - image_name = data.get("image_name", "") - excel_url = None - image_url = None - if excel_name: - excel_url = f"/api/files/download/?agent_id=basic_excel_talk&file_id={excel_name}&file_type=excel" - if image_name: - image_url = f"/api/files/download/?agent_id=basic_excel_talk&file_id={image_name}&file_type=image" - result = {"message": output, "type": "message", "excel_url": excel_url, "image_url": image_url} - await websocket.send_json(result | data) - except json.JSONDecodeError as e: - print(f"Error decoding JSON: {e}") - print(f"Response text: {text}") - except Exception as e2: - result = {"message": f"鍐呴儴閿欒锛� {e2}", "type": "close"} - await websocket.send_json(result) - print(f"Error process message of basic agent: {e2}") + if result[:5] == "data:": + # 濡傛灉鏄紝鍒欐埅鍙栨帀鍓�5涓瓧绗︼紝骞跺幓闄ら灏剧┖鐧界 + text = result[5:].strip() + else: + # 鍚﹀垯锛屼繚鎸佸師鏍� + text = result + try: + data = json.loads(text) + output = data.get("output", "") + file_name = data.get("filename", "") + + excel_url = None + if file_name: + excel_url = f"/api/files/download/?agent_id=basic_question_talk&file_id={file_name}&file_type=word" + result = {"message": output, "type": "message", "file_url": excel_url} + await websocket.send_json(result | data) + except json.JSONDecodeError as e: + print(f"Error decoding JSON: {e}") + # print(f"Response text: {text}") + except Exception as e2: + result = {"message": f"鍐呴儴閿欒锛� {e2}", "type": "close"} + await websocket.send_json(result) + print(f"Error process message of basic agent: {e2}") + else: + async for result in service.excel_talk(question, chat_id): + try: + if result[:5] == "data:": + # 濡傛灉鏄紝鍒欐埅鍙栨帀鍓�5涓瓧绗︼紝骞跺幓闄ら灏剧┖鐧界 + text = result[5:].strip() + else: + # 鍚﹀垯锛屼繚鎸佸師鏍� + text = result + try: + data = json.loads(text) + output = data.get("output", "") + excel_name = data.get("excel_name", "") + image_name = data.get("image_name", "") + excel_url = None + image_url = None + if excel_name: + excel_url = f"/api/files/download/?agent_id=basic_excel_talk&file_id={excel_name}&file_type=excel" + if image_name: + image_url = f"/api/files/download/?agent_id=basic_excel_talk&file_id={image_name}&file_type=image" + result = {"message": output, "type": "message", "excel_url": excel_url, "image_url": image_url} + await websocket.send_json(result | data) + except json.JSONDecodeError as e: + print(f"Error decoding JSON: {e}") + # print(f"Response text: {text}") + except Exception as e2: + result = {"message": f"鍐呴儴閿欒锛� {e2}", "type": "close"} + await websocket.send_json(result) + print(f"Error process message of basic agent: {e2}") except Exception as e: await websocket.send_json({"message": str(e), "type": "error"}) finally: -- Gitblit v1.8.0