使用 Llama 3.2 构建一个本地版 PDF 聊天助手

基于本地部署的 Llama 3.2 模型与 Embedchain+ChromaDB 构建离线 PDF 聊天助手,支持上传 PDF、自动解析内容并用自然语言问答,全程无需联网。使用 Streamlit 搭建简洁交互界面,适合希望在本地安全处理敏感文档的技术用户快速上手。

发布于2024年9月28日 03:22
编辑零重力瓦力
评论0
阅读44

Meta 推出了新的开源模型 Llama 3.2。新版模型体积更小、生成令牌速度更快、准确度也更高,能够方便的构建基于 RAG 的 AI 应用。这个教程将展示如何使用 Llama 3.2 和 RAG 构建一个简单而强大的 PDF 聊天助手。到时,您能够上传PDF文件并向它提出问题。所有操作都在本地完成,完全免费无需联网。

构建目标

PDF 聊天助手使用 Llama 3.2 和 RAG 分析 PDF 文档,并根据它的内容回答问题。

  • 使用 Streamlit 创建一个简单的使用界面
  • 将 RAG 与 Llama 3.2 的强大功能相结合
  • 使用 Embedchain 框架实现 RAG 功能
  • 使用 ChromaDB 存储 PDF 内容的向量

前提条件

  • 需要在本地电脑安装 Python(建议使用 3.7 或更高版本)
  • 对 Python 编程有基本的了解
  • 选择一个你熟悉的 Python 代码编辑器(推荐 VSCode 或 PyCharm)

构建步骤

第一步:环境设置

1. 克隆 GitHub 仓库

git clone https://github.com/Shubhamsaboo/awesome-llm-apps.git

2. 前往 chat_with_pdf 文件夹

cd chat_with_pdf

3. 安装应用依赖项

pip install -r requirements.txt

第二步:创建 Streamlit 应用

创建一个新文件 chat_pdf.py 并添加以下代码:

1. 导入所需库

在文件顶部添加

import os
import tempfile
import streamlit as st
from embedchain import App
import base64
from streamlit_chat import message

2. 配置应用程序

在这个应用程序中,我们将使用 Ollama 的 Llama-3.2。您也可以选择 OpenAI、Anthropic 或其他任何 LLM。

使用开源的 ChromaDB 作为矢量数据库(您可以自由选择任何其他矢量数据库)。

def embedchain_bot(db_path):
    return App.from_config(
        config={
            "llm": {"provider": "ollama", "config": {"model": "llama3.2:latest", "max_tokens": 250, "temperature": 0.5, "stream": True, "base_url": 'http://localhost:11434'}},
            "vectordb": {"provider": "chroma", "config": {"dir": db_path}},
            "embedder": {"provider": "ollama", "config": {"model": "llama3.2:latest", "base_url": 'http://localhost:11434'}},
        }
    )

3. 处理 PDF 文件的上传和预览

def display_pdf(file):
    base64_pdf = base64.b64encode(file.read()).decode('utf-8')
    pdf_display = f''
    st.markdown(pdf_display, unsafe_allow_html=True)

4. 设置 Streamlit 应用程序

Streamlit 允许您仅使用 Python 代码创建用户界面。对于这个应用程序,我们将:

  • 使用'st.title()' 为应用程序添加标题
  • 使用'st.caption()' 为应用程序添加描述

5. 创建一个用于PDF上传和预览的侧边栏

with st.sidebar:
    st.header("PDF Upload")
    pdf_file = st.file_uploader("Upload a PDF file", type="pdf")

    if pdf_file:
        st.subheader("PDF Preview")
        display_pdf(pdf_file)

6. 将 PDF 添加到知识库。当上传 PDF 时,内容会被处理并添加到 ChromaDB 中以供检索。

  if st.button("Add to Knowledge Base"):
            with st.spinner("Adding PDF to knowledge base..."):
                with tempfile.NamedTemporaryFile(delete=False, suffix=".pdf") as f:
                    f.write(pdf_file.getvalue())
                    st.session_state.app.add(f.name, data_type="pdf_file")
                os.remove(f.name)
            st.success(f"Added {pdf_file.name} to knowledge base!")

7. 创建一个聊天界面,让用户可以向 PDF 文件提出问题

for i, msg in enumerate(st.session_state.messages):
    message(msg["content"], is_user=msg["role"] == "user", key=str(i))

if prompt := st.chat_input("Ask a question about the PDF"):
    st.session_state.messages.append({"role": "user", "content": prompt})
    message(prompt, is_user=True)

8. 处理用户问题并显示回复,并添加一个清除聊天历史记录的按钮

 with st.spinner("Thinking..."):
        response = st.session_state.app.chat(prompt)
        st.session_state.messages.append({"role": "assistant", "content": response})
        message(response)

if st.button("Clear Chat History"):
    st.session_state.messages = []

第三步:运行应用

1. 在终端中,进入项目文件夹,并运行以下命令,启动 Streamlit 应用

streamlit run chat_pdf.py

Streamlit 会提供一个本地 URL(通常是 http://localhost:8501)。通过浏览器打开这个链接就可以了。

相关文章

氛围编程的下半场:你的 AI 编程 Agent 已经不需要你的电脑了
AI 编程开发
2026年5月17日
0 条评论
零重力瓦力

氛围编程的下半场:你的 AI 编程 Agent 已经不需要你的电脑了

氛围编程竞争焦点已从代码补全转向云端 Agent 独立完成工程任务。Cursor 推出 Cloud Agent 环境,支持多仓库挂载、环境配置即代码及严格的安全治理。开放 TypeScript SDK,使 Agent 可集成至 CI/CD 或内部产品,实现本地与云端部署对称。同时,Agent Harness 优化通过 Keep Rate 等指标提升模型表现。Mistral Vibe 和 Google Antigravity 亦印证此趋势:编程 Agent 脱离本地束缚,向自主执行、基础设施化演进。

#AI 编程#智能体工程
阅读全文
AI 不够聪明?也许只是没有给对上下文!
AI 新闻资讯
2026年5月13日
0 条评论
小创

AI 不够聪明?也许只是没有给对上下文!

AI 输出质量差往往不是因为模型不行,而是缺乏有效的上下文。近期备受关注的 “上下文工程” 正是解决这一瓶颈。通过数据打通、知识层构建、精准检索和运行时治理,让 AI 获取与任务真正相关的信息。在检索环节,相比基础 RAG,智能体式 RAG 能迭代获取数据,GraphRAG 靠实体关系导航提升精度,上下文压缩则过滤噪音最大化信号。当模型能力边际放缓,上下文工程的质量将成为拉开 AI 应用差距的关键。

#RAG#上下文工程#智能体工程
阅读全文
Mistral 把编程 Agent 扔进云里
AI 编程开发
2026年5月12日
0 条评论
零重力瓦力

Mistral 把编程 Agent 扔进云里

Mistral 推出 Medium 3.5 开源模型与 Vibe 远程代理,将编程协作从“人机同步”转向“异步委派”。128B 稠密模型以 77.6% 的 SWE-Bench 成绩超越 Claude Sonnet 4,支持自部署。Vibe 允许开发者在云端沙箱并行运行多个任务,自动提交 PR 并通知审查。配合 Le Chat 通用工作模式,该方案适合追求效率的团队及关注数据安全的独立开发者,重新定义了 AI 辅助编码的工作流。

#Mistral#开源模型#AI 编程
阅读全文
互动讨论

评论区

围绕《使用 Llama 3.2 构建一个本地版 PDF 聊天助手》展开交流,未登录用户可浏览评论,登录后可参与讨论。

评论数
0
登录后参与评论
支持发表观点与回复一级评论,互动后将同步到消息中心。
登录后评论
暂无评论,欢迎成为第一个参与讨论的人。