koubeiGPT / app.py
xrunda's picture
Update app.py
0ececde
import os
from langchain.schema import Document
from langchain.embeddings.openai import OpenAIEmbeddings
from langchain.chat_models import ChatOpenAI
from langchain.prompts import PromptTemplate
from langchain.chains import LLMChain
from langchain.vectorstores import Chroma
from dotenv import load_dotenv
from langchain.llms import OpenAI
from langchain.retrievers.self_query.base import SelfQueryRetriever
from langchain.chains.query_constructor.base import AttributeInfo
import streamlit as st
import pandas as pd
import json
load_dotenv()
embeddings = OpenAIEmbeddings()
vectorstore = Chroma(persist_directory="./chroma_db_modelY_2", embedding_function=embeddings)
metadata_field_info = [
AttributeInfo(
name="brand",
description="汽车品牌",
type="string",
),
AttributeInfo(
name="model",
description="车型",
type="string",
),
AttributeInfo(
name="name",
description="具体车型名称",
type="string",
),
AttributeInfo(
name="year",
description="上市年份",
type="integer",
),
AttributeInfo(
name="price",
description="售价",
type="string"
)
]
document_content_description = "汽车车型的用户评价"
llm = OpenAI(temperature=0)
retriever = SelfQueryRetriever.from_llm(
llm, vectorstore, document_content_description, metadata_field_info, verbose=True
)
# 2.检索生成结果
def retrieve_info(query):
return retriever.get_relevant_documents(query=query)
# 3.设置LLMChain和提示
llm=ChatOpenAI(temperature=0, model='gpt-3.5-turbo-16k-0613')
template = """
你是一名掌握了全部汽车用户真实使用评价内容的智能回复机器人。
我将发送给你一位客户关于汽车使用、购买建议、与其他品牌车型对比等方面的问题。
客户希望你在真实车主评价的基础上,归纳总结形成一句结论性的内容,发送给这位客户,并遵循以下所有规则。
1/ 在篇幅、语气、逻辑论证和其他细节方面,答复应与尽可能的给人专业的感觉,如实客观的表达问题的答案,不要增加你自己的幻觉。
2/ 如果在真实车主评价内容中没有这个问题的相关答案,请回答:“很抱歉,基于真实车主的口碑数据,我暂时不能给出您这个问题的答案。“
{message}
以下是针对这个问题,真实车主评价内容:
{best_practice}
请为这个客户返回最符合问题的最佳回复内容:
所有回复均为中文
"""
prompt=PromptTemplate(
input_variables=["message","best_practice"],
template=template
)
chain=LLMChain(llm=llm,prompt=prompt)
# 4.检索生成结果
def generate_response(message):
best_practice = retrieve_info(message)
# 获取每个 Document 对象中的 page_content 属性,并将其内容组合为一个字符串
best_practice_text = "<br>".join([doc.page_content for doc in best_practice])
# 在页面上以较小的字体打印 best_practice_text 变量的内容,并设置颜色为淡灰色
st.markdown(f'<small style="color: #aaaaaa;">召回内容:<br>{best_practice_text}</small>', unsafe_allow_html=True)
response = chain.run(message=message,best_practice=best_practice)
return response
def main():
st.header("汽车口碑GPT 🚗")
message = st.text_area("问问我吧:我知道关于特斯拉ModelY的一切问题:冬天续航衰减多少?后备箱能放下自行车么?")
if message:
result_placeholder = st.empty() # 创建一个空位,用于显示临时消息
result_placeholder.write("正在生成回复内容,请稍后...")
result = generate_response("特斯拉ModelY"+message)
st.info(result)
result_placeholder.empty() # 清空临时消息
if __name__ == "__main__":
main()