从零开始构建一个 RAG + Flask 问答系统

🧠 用 Flask + HuggingFace + OpenRouter 打造一个免费的 RAG 问答系统(完整教学)

✅ 项目介绍

我们要做一个网页,可以上传 .txt 文档,然后问它问题,它会回答你。

这个功能背后用了 AI 模型,但我们不会花钱,全程使用免费的模型和服务!


🧱 步骤一:准备环境

1. 创建一个新文件夹

复制代码
mkdir rag_flask_app
cd rag_flask_app

2. 创建并激活虚拟环境(可选但推荐)

复制代码
conda create -n rag_env python=3.10 -y
conda activate rag_env

3. 安装依赖

创建一个 requirements.txt 文件:

复制代码
flask
llama-index>=0.10.0
sentence-transformers
llama-index-embeddings-huggingface
openai

安装依赖:

复制代码
pip install -r requirements.txt

📁 步骤二:构建项目结构

复制代码
mkdir templates
mkdir uploads
touch app.py templates/index.html

🧠 步骤三:写入核心代码

🔹 app.py(主逻辑)

复制代码
from flask import Flask, render_template, request
import os
from llama_index.core import SimpleDirectoryReader, VectorStoreIndex
from llama_index.embeddings.huggingface import HuggingFaceEmbedding
from llama_index.llms.openai import OpenAI
from llama_index.core.settings import Settings

# 初始化 Flask
app = Flask(__name__)
UPLOAD_FOLDER = 'uploads'
os.makedirs(UPLOAD_FOLDER, exist_ok=True)

# 设置模型
embed_model = HuggingFaceEmbedding(model_name="all-MiniLM-L6-v2")  # 本地嵌入模型
llm = OpenAI(
    api_base="https://openrouter.ai/api/v1",
    api_key="sk-or-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx",  # 👉 填你的 OpenRouter Key
    model="gpt-3.5-turbo"
)

# 应用到 LlamaIndex 设置
Settings.embed_model = embed_model
Settings.llm = llm

index = None

@app.route('/', methods=['GET', 'POST'])
def index_page():
    global index
    response = ""

    if request.method == 'POST':
        if 'file' in request.files:
            file = request.files['file']
            filepath = os.path.join(UPLOAD_FOLDER, file.filename)
            file.save(filepath)

            documents = SimpleDirectoryReader(UPLOAD_FOLDER).load_data()
            index = VectorStoreIndex.from_documents(documents)
            response = "Document uploaded and indexed!"

        elif 'question' in request.form and index is not None:
            question = request.form['question']
            query_engine = index.as_query_engine()
            response = query_engine.query(question).response

    return render_template("index.html", response=response)

if __name__ == '__main__':
    app.run(debug=True)

🔹 templates/index.html(网页界面)

复制代码
<!DOCTYPE html>
<html>
<head>
    <title>RAG Web App</title>
</head>
<body>
    <h1>🧠 RAG + LLM Document QA</h1>

    <form method="POST" enctype="multipart/form-data">
        <p><strong>Upload a .txt document:</strong></p>
        <input type="file" name="file" required>
        <input type="submit" value="Upload">
    </form>

    <form method="POST">
        <p><strong>Ask a question about the document:</strong></p>
        <input type="text" name="question" required style="width:300px;">
        <input type="submit" value="Ask">
    </form>

    <h2>Answer:</h2>
    <p>{{ response }}</p>
</body>
</html>

🔑 步骤四:获取免费 OpenRouter Key

  1. 注册:https://openrouter.ai

  2. 登录后点击右上角头像 → API Keys

  3. 创建新 key,会像这样:

    复制代码
    sk-or-v1-xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx
  4. app.py 中粘贴进去替换


🚀 步骤五:运行你的应用!

在终端里运行:

复制代码
python app.py

打开浏览器访问: 👉 http://127.0.0.1:5000


🧪 测试流程

  1. 上传一个 .txt 文档(例如一段英文文章)

  2. 输入问题,比如:

    • "What is the main topic?"

    • "Who is the author?"

  3. 系统会返回基于文档的智能回答 ✅

相关推荐
AI_56785 小时前
AI无人机如何让安全隐患无处遁形
人工智能·无人机
机器之心5 小时前
DeepSeek强势回归,开源IMO金牌级数学模型
人工智能·openai
机器之心5 小时前
华为放出「准万亿级MoE推理」大招,两大杀手级优化技术直接开源
人工智能·openai
大力财经5 小时前
零跑Lafa5正式上市 以“五大硬核实力”开启品牌个性化新篇章
人工智能
ECT-OS-JiuHuaShan5 小时前
否定之否定的辩证法,谁会不承认?但又有多少人说的透?
开发语言·人工智能·数学建模·生活·学习方法·量子计算·拓扑学
软件开发技术深度爱好者5 小时前
基于多个大模型自己建造一个AI智能助手(增强版)
人工智能
骥龙5 小时前
4.12、隐私保护机器学习:联邦学习在安全数据协作中的应用
人工智能·安全·网络安全
天硕国产存储技术站5 小时前
DualPLP 双重掉电保护赋能 天硕工业级SSD筑牢关键领域安全存储方案
大数据·人工智能·安全·固态硬盘
腾讯云开发者5 小时前
AI独孤九剑:AI没有场景,无法落地?不存在的。
人工智能
光影少年5 小时前
node.js和nest.js做智能体开发需要会哪些东西
开发语言·javascript·人工智能·node.js