38 lines
1.5 KiB
Python
38 lines
1.5 KiB
Python
## 最简单的版本,只支持固定的知识库
|
|
|
|
# ## 单独运行的时候需要添加
|
|
# import sys
|
|
# import os
|
|
# sys.path.append(os.path.dirname(os.path.dirname(os.path.dirname(os.path.dirname(os.path.abspath(__file__))))))
|
|
|
|
from server.chat.knowledge_base_chat import knowledge_base_chat
|
|
from configs import VECTOR_SEARCH_TOP_K, SCORE_THRESHOLD
|
|
import json
|
|
import asyncio
|
|
from server.agent import model_container
|
|
|
|
async def search_knowledge_base_iter(database: str, query: str) -> str:
|
|
response = await knowledge_base_chat(query=query,
|
|
knowledge_base_name=database,
|
|
model_name=model_container.MODEL.model_name,
|
|
temperature=0.01,
|
|
history=[],
|
|
top_k=VECTOR_SEARCH_TOP_K,
|
|
prompt_name="knowledge_base_chat",
|
|
score_threshold=SCORE_THRESHOLD,
|
|
stream=False)
|
|
|
|
contents = ""
|
|
async for data in response.body_iterator: # 这里的data是一个json字符串
|
|
data = json.loads(data)
|
|
contents = data["answer"]
|
|
docs = data["docs"]
|
|
return contents
|
|
|
|
def knowledge_search_simple(query: str):
|
|
return asyncio.run(search_knowledge_base_iter(query))
|
|
|
|
|
|
if __name__ == "__main__":
|
|
result = knowledge_search_simple("大数据男女比例")
|
|
print("答案:",result) |