Python結合ollama和stramlit開發聊天機器人

Python結合ollama和stramlit開發聊天機器人

  • 一、環境準備
    • 1、streamlit安裝
    • 2、langchain安裝
    • 3、ollama的安裝
  • 二、Ollama平臺聊天機器人實現
    • 1、需求
    • 2、模型調用
    • 3、前端實現
      • 頁面呈現
      • 代碼實現
  • 三、詳細代碼地址
  • 四、參考資源

一、環境準備

1、streamlit安裝

# 通過 pip 安裝
pip install streamlit# 驗證安裝
streamlit hello

運行應用:

streamlit run main.py

如果運行不成功,可以帶上Python版本運行

python3.13 -m streamlit run main.py

瀏覽器會自動打開 http://localhost:8501 顯示應用。

2、langchain安裝

參考下面的文章

你好! 這是你第一次使用 Markdown編輯器 所展示的歡迎頁。如果你想學習如何使用Markdown編輯器, 可以仔細閱讀這篇文章,了解一下Markdown的基本語法知識。

3、ollama的安裝

參考下面
文章
mac ollama install

二、Ollama平臺聊天機器人實現

1、需求

構建一個基于大模型的本地智能聊天機器人。該聊天機器人將集成先進的大規模預訓練語言模型(如GPT、Qwen等),具備自然語言理解、多輪對話、情感分析、知識問答等核心功能。

項目采用模塊化設計,前端通過Streamlit框架實現簡潔易用的交互界面,后端基于Ollama等平臺進行模型部署和管理,確保系統的高效性和可擴展性。

2、模型調用

import ollama# 接收用戶輸入的提示詞
def get_response(prompt):# 指定模型,傳遞角色 和提示詞response = ollama.chat(model="qwen2:0.5b",messages=[{"role": "user","content": prompt,},],)return response.message.content

3、前端實現

頁面呈現

訪問地址
頁面:
在這里插入圖片描述

代碼實現

"""
該模塊用于充當聊天機器人的前端模塊,
接收用戶輸入的問題,調用chat_utils模塊,獲取回復,
通過streamlit模塊,將回復并顯示給用戶
"""
# streamlit庫:python 代碼實現前端頁面開發并部署
import streamlit as st# 聊天機器人核心模塊
# ConversationBufferMemory存儲聊天機器人的會話記錄
from langchain.memory import ConversationBufferMemory
import chat_utils# 標題
st.title("zeoy's chat robot")# 判斷是否有歷史聊天記錄數據,如果沒有就創建,并存儲所有記錄消息# st.session_state存儲會話狀態,用于存儲會話數據
if "history" not in st.session_state:# 創建一個conversationBufferMemory對象,用于存儲會話記錄st.session_state.memory = ConversationBufferMemory()# 添加聊天機器人的歡迎語句st.session_state.message = [{"role": "assistant", "content": "welcome to zeoy's chat robot."}]# 遍歷session_state.message列表,
for message in st.session_state.message:#  聊天消息 顯示當前角色內容with st.chat_message(message["role"]):st.markdown(message["content"])# 接收用戶錄入的內容
promt = st.chat_input("請輸入你要咨詢的問題")# 判斷用戶輸入的內容是否為空
if promt:# 顯示用戶輸入的內容st.session_state.message.append({'role': 'user', 'content': promt})st.chat_message('user').markdown(promt)# 獲取機器人的回復response = chat_utils.get_response(promt)# 顯示機器人的回復with st.chat_message("assistant"):st.markdown(response)# 將用戶輸入的內容和機器人的回復添加到session_state.message列表中st.session_state.message.append({'role': 'assistant', 'content': response})

三、詳細代碼地址

github:https://github.com/zeoyzhaogithub/AI-ChatBot

四、參考資源

官方文檔: https://docs.streamlit.io/

示例庫: https://streamlit.io/gallery

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/81863.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/81863.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/81863.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java jdbc執行Oracle sql文件

執行代碼 import java.io.FileInputStream; import java.io.InputStreamReader; import java.nio.charset.StandardCharsets; import java.sql.Connection; import java.sql.DriverManager;import org.apache.ibatis.jdbc.ScriptRunner;public class ExecSqlFileController {pu…

[Java實戰]Spring Boot整合MinIO:分布式文件存儲與管理實戰(三十)

[Java實戰]Spring Boot整合MinIO:分布式文件存儲與管理實戰(三十) 一、MinIO簡介與核心原理 MinIO 是一款高性能、開源的分布式對象存儲系統,兼容 Amazon S3 API,適用于存儲圖片、視頻、日志等非結構化數據。其核心特…

開發指南115-CSS中選擇器關系

1、選擇后代 可以用選擇器1 選擇器2(中間用空格分隔)來表達,也可以在大括號里通過包含關系來表達 舉例 .a .b 舉例.a { .b{} } 注意css本身并不支持嵌套的寫法,是scss等提供的擴展能力。 2、選擇直系后代 選擇器1 > 選擇器2&a…

創建型:抽象工廠模式

目錄 1、核心思想 2、實現方式 2.1 模式結構 2.2 實現案例 3、優缺點分析 4、適用場景 1、核心思想 目的:統一管理相關對象的創建,確保產品兼容性。優先用于需要強約束產品兼容性的場景(如UI主題、跨平臺適配) 概念&#…

乘最多水的容器 | 算法 | 給定一個整數數組。有n條垂線。找出其中的兩條線,使得它們與 x 軸共同構成的容器可以容納最多的水。

在我們日常生活中,蓄水似乎是一個極為樸素的物理行為:兩堵墻之間,注入水,看誰能裝得更多。可如果換個角度,從算法的視角去看這個問題,它會變得怎樣?你是否意識到,這樣一個簡單的問題…

無人機避障——深藍學院浙大Ego-Planner規劃部分

ESDF-free: 被這種類型的障礙物死死卡住的情況: 在一定范圍內建立ESDF: Ego-Planner框架: 找到{p,v} pair: 【注意】:首先根據在障礙物內航跡上的點Q,以及與它相鄰但不在障礙物內的兩個點&#…

零基礎設計模式——大綱匯總

零基礎學設計模式 - 大綱 前言 本教程旨在幫助零基礎的同學快速入門設計模式,理解其核心思想和應用場景。我們將通過清晰的講解和簡單的示例,逐步引導你掌握常用的設計模式。 第一部分:設計模式入門 什么是設計模式? 設計模式…

leetcode 92. Reverse Linked List II

題目描述 92. Reverse Linked List II 是第206題的進階版206. Reverse Linked List 思路很簡單,但一次性通過還是有點難度的。 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(n…

CUDA的設備,流處理器(Streams),核,線程塊(threadblock),線程,網格(?gridDim),塊(block)和多gpu設備同步數據概念

CUDA的設備,流處理器,核,線程塊(threadblock),線程,網格(?gridDim),塊(block)和多gpu設備同步數據概念 CUDA的設備,流處理器,核&…

spring5-配外部文件-spEL-工廠bean-FactoryBean-注解配bean

spring配外部文件 我們先在Spring里配置一個數據源 1.導c3p0包,這里我們先學一下hibernate持久化框架&#xff0c;以后用mybites. <dependency><groupId>org.hibernate</groupId><artifactId>hibernate-core</artifactId><version>5.2.…

Feature Toggle 不再亂:如何設計一個干凈、安全、可控的特性開關系統?

網羅開發 &#xff08;小紅書、快手、視頻號同名&#xff09; 大家好&#xff0c;我是 展菲&#xff0c;目前在上市企業從事人工智能項目研發管理工作&#xff0c;平時熱衷于分享各種編程領域的軟硬技能知識以及前沿技術&#xff0c;包括iOS、前端、Harmony OS、Java、Python等…

技術分享:大數據挖掘平臺架構設計與行業應用實踐

在數字化轉型浪潮下&#xff0c;企業數據規模呈指數級增長。如何構建高效的數據挖掘體系&#xff0c;實現數據價值變現&#xff0c;成為技術團隊面臨的重要課題。本文將深入探討大數據挖掘平臺的核心架構、關鍵技術及行業應用實踐。 一、平臺架構設計 1. 數據采集層 支持多源異…

計算機視覺與深度學習 | EMD-KPCA-LSTM、EMD-LSTM、LSTM回歸預測對比,多輸入單輸出(Matlab完整程序和數據)

以下是針對EMD-KPCA-LSTM、EMD-LSTM和LSTM回歸預測對比的完整可運行MATLAB實現。包含數據生成、特征處理、模型構建和性能評估全流程,并提供關鍵代碼注釋和注意事項。 完整代碼實現(含數據生成) %% 清理環境 clear; clc; close all; warning off;%% 生成模擬數據(正弦波+噪…

Axure應用交互設計:動態面板嵌套實現超強體驗感菜單表頭

親愛的小伙伴,在您瀏覽之前,煩請關注一下,在此深表感謝!如有幫助請訂閱專欄! Axure產品經理精品視頻課已登錄CSDN可點擊學習https://edu.csdn.net/course/detail/40420 課程主題:動態面板嵌套 主要內容:利用動態面板多層嵌套實現菜單表頭 應用場景:廣泛應用于表單表…

HarmonyOS 鴻蒙應用開發基礎:父組件和子組件的通信方法總結

在鴻蒙開發中&#xff0c;ArkUI聲明式UI框架提供了一種現代化、直觀的方式來構建用戶界面。然而&#xff0c;由于其聲明式的特性&#xff0c;父組件與子組件之間的通信方式與傳統的命令式框架有所不同。本文旨在詳細探討在ArkUI框架中&#xff0c;父組件和子組件通信的方法總結…

深度學習模塊縫合拼接方法套路+即插即用模塊分享

前言 在深度學習中&#xff0c;模型的設計往往不是從頭開始&#xff0c;而是通過組合不同的模塊來構建。這種“模塊縫合”技術&#xff0c;就像搭積木一樣&#xff0c;把不同的功能模塊拼在一起&#xff0c;形成一個強大的模型。今天&#xff0c;我們就來聊聊四種常見的模塊縫…

計算機網絡(2)——應用層

1.應用層概述 應用層(Application Layer)屬于計算機網絡體系結構中的最頂層&#xff0c;直接面向用戶&#xff0c;提供各種網絡服務和應用程序的接口 本文主要的學習內容如下&#xff1a; (1)網絡應用進程通信方式 客戶端-服務器方式點對點方式混合方式 (2)網絡應用的需求與傳輸…

Android 繪制折線圖

用了一段時間的 Jetpack Compose ,感覺寫 UI 的效率確實會提升不少 。 配合 AI 編程繪制了一個折線圖。供大家學習參考! @Composable fun TemperatureChart() {val timeLabels = listOf("7:00", "8:00", "9:00", "10:00", "11:…

JavaScript- 1.3 DOM對頁面內容進行操作

本系列可作為前端學習系列的筆記&#xff0c;代碼的運行環境是在HBuilder中&#xff0c;小編會將代碼復制下來&#xff0c;大家復制下來就可以練習了&#xff0c;方便大家學習。 HTML和CSS系列文章 已經收錄在前端專欄&#xff0c;有需要的寶寶們可以點擊前端專欄查看&#xff…

CSS-5.1 Transition 過渡

本系列可作為前端學習系列的筆記&#xff0c;代碼的運行環境是在HBuilder中&#xff0c;小編會將代碼復制下來&#xff0c;大家復制下來就可以練習了&#xff0c;方便大家學習。 HTML系列文章 已經收錄在前端專欄&#xff0c;有需要的寶寶們可以點擊前端專欄查看&#xff01; 點…