我用Streamlit+LLM(大型语言模型)轻松实现Web聊天
admin 阅读: 2024-03-29
后台-插件-广告管理-内容页头部广告(手机) |
Streamlit是时下比较热门的一个基于Python的Web应用程序框架,它可以在几分钟内将数据转化为可共享的Web应用程序,无需前端开发经验,使用纯Python代码实现,简单且高效。ChatGPT是目前非常火的OpenAI公司开发的聊天机器人模型,它无所不知就像一本大百科全书,它可以帮你做很多繁杂的日常工作,比如可以代你写文章,代你做excel表格,甚至代你写代码。今天我们要将两者结合起来开发一个基于web的应用聊天小程序。
安装OpenAPI和Streamlit包
我们需要在python环境中安装openai和streamlit的第三方python包,可以通过在命令行窗口中安装这些包:
- pip install openai
- pip install streamlit
- pip install streamlit_chat
聊天机器人接口参数说明
- model:模型名词
- prompt:您对机器人提出的问题
- temperature:温度参数,该参数控制生成文本的随机性级别。较高的温度参数会导致更多变化且可能不太连贯的响应,而较低的t温度参数会产生更可预测且可能更连贯的响应。
- max_tokens:应答语句的长度
创建聊天Python代码文件
我们需要创建一个用于聊天的streamlit的代码文件 chat_bot.py:
- # chat_bot.py
- import openai
- import streamlit as st
- from streamlit_chat import message
- #申请的api_key
- openai.api_key = "xxxxxxxxxxxxxxxxx"
- def generate_response(prompt):
- completion=openai.Completion.create(
- model='text-davinci-003',
- prompt=prompt,
- max_tokens=1024,
- temperature=0.6
- )
- message=completion.choices[0].text
- return message
- st.markdown("#### 我是ChatGPT聊天机器人,我可以回答您的任何问题!")
- if 'generated' not in st.session_state:
- st.session_state['generated'] = []
- if 'past' not in st.session_state:
- st.session_state['past'] = []
- user_input=st.text_input("请输入您的问题:",key='input')
- if user_input:
- output=generate_response(user_input)
- st.session_state['past'].append(user_input)
- st.session_state['generated'].append(output)
- if st.session_state['generated']:
- for i in range(len(st.session_state['generated'])-1, -1, -1):
- message(st.session_state["generated"][i], key=str(i))
- message(st.session_state['past'][i],
- is_user=True,
- key=str(i)+'_user')
启动Streamlit
我们需要在命令行窗口执行启动streamlit的命令:
streamlit run chat_bot.py输入启动streamlit命令后,会弹出浏览器, 如果没有弹出浏览器可以自行打开浏览器并输入上图中的url地址,接下来就可以开始和ChatGPT聊天了:
参考资料
Streamlit documentation
OpenAI API documentation
声明
1.本站遵循行业规范,任何转载的稿件都会明确标注作者和来源;2.本站的原创文章,请转载时务必注明文章作者和来源,不尊重原创的行为我们将追究责任;3.作者投稿可能会经我们编辑修改或补充。
在线投稿:投稿 站长QQ:1888636
后台-插件-广告管理-内容页尾部广告(手机) |