news 2026/6/9 2:24:13

最简单的LangChain和RAG

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
最简单的LangChain和RAG

ollama的API:https://docs.ollama.com/api/ps
ollama的API:https://github.com/ollama/ollama/blob/main/docs/api.md?utm_source=chatgpt.com

Ollama API ├── 推理类(最常用) │ ├──/api/generate ← 单轮生成 │ ├──/api/chat ← 多轮对话 │ └──/api/embed ← 向量 embedding │ ├── 模型管理 │ ├──/api/tags ← 已有模型 │ ├──/api/pull ← 下载模型 │ ├──/api/push ← 推送模型 │ ├──/api/create ← 构建模型 │ └──/api/delete← 删除模型 │ ├── 运行控制 │ ├──/api/show ← 模型信息 │ └──/api/ps ← 当前运行模型 │ └── 底层服务 └──/api/version ← Ollama 版本
curl http://localhost:11434/api/tags
curl http://localhost:11434/api/generate \ -X POST \ -H "Content-Type: application/json" \ -d '{"model":"deepseek-r1:7b","prompt":"用一句话解释什么是UNet","stream":false}'

//这个将会是流式的

curl http://localhost:11434/api/chat \ -X POST \ -H "Content-Type: application/json" \ -d '{"model":"deepseek-r1:7b","messages":[{"role":"system","content":"你是一个AI老师"},{"role":"user","content":"解释什么是UNet"}]}'

//这会在ollama中创建一个my-deepseek的model,它来自eepseek-r1:7b,与它的区别是,以后每次问题问题之前都会自动加上一句你是AI工程师。

POST/api/create{"name":"my-deepseek","modelfile":"FROM deepseek-r1:7b\nSYSTEM 你是AI工程师"}

//把input的字符串通过embed模型,转换成ebbedding

curl http://localhost:11434/api/embed -X POST -H "Content-Type: application/json" \ -d '{"model":"nomic-embed-text","input":"UNet 是什么"}'

一个最小的LangChain

//环境准备

curl-fsSL https://ollama.com/install.sh | shollama serve//开启服务ollama pull deepseek-r1:7b ollama run deepseek-r1:7b pip install langchain langchain-community ollama pull nomic-embed-text//embedding 模型

//代码

from langchain_community.llms import Ollama # 连接本地 ollama llm=Ollama(model="deepseek-r1:7b",base_url="http://localhost:11434")# 最简单的调用 response=llm.invoke("用一句话解释什么是卷积神经网络")#不会暴露 thinking 不会暴露 context 只拿到responseprint(response)

一个最小的RAG

用LangChain做RAG,读取本地数据
//环境准备

curl-fsSL https://ollama.com/install.sh | shollama serve//开启服务ollama pull deepseek-r1:7b ollama run deepseek-r1:7b pip install langchain langchain-community langchain-text-splitters faiss-cpu ollama pull nomic-embed-text//embedding 模型

//代码

from langchain_community.llms import Ollama from langchain_community.document_loaders import TextLoader from langchain_text_splitters import RecursiveCharacterTextSplitter from langchain_community.embeddings import OllamaEmbeddings from langchain_community.vectorstores import FAISS from langchain.chains import RetrievalQA OLLAMA_URL="http://localhost:11434"README_PATH="/home/yqw/tt/ai/README.md"#1.LLM(你原来那套) llm=Ollama(model="deepseek-r1:7b",base_url=OLLAMA_URL)#2.读取 README.md loader=TextLoader(README_PATH)documents=loader.load()#3.切分文档 splitter=RecursiveCharacterTextSplitter(chunk_size=500,chunk_overlap=100)documents=splitter.split_documents(documents)#4.Embedding embeddings=OllamaEmbeddings(model="nomic-embed-text",base_url=OLLAMA_URL)vectorstore=FAISS.from_documents(documents,embeddings)#5.构建 QA 链 qa=RetrievalQA.from_chain_type(llm=llm,retriever=vectorstore.as_retriever(),chain_type="stuff")#6.提问 question="README.md 这个项目是做什么的,同时介绍一下吴亦凡的现状?"result=qa.invoke({"query":question})answer=result["result"]print("Q:",question)print("A:",answer)
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/9 19:06:35

破碎机远程监控及远程维护的数字化解决方案

行业背景近年来,随着我国工业化、城镇化进程的加速推进,砂石骨料作为混凝土及砂浆的关键基础材料,在建筑、交通、水利等基础设施建设领域得到了广泛应用。这一趋势为破碎筛分设备行业带来了前所未有的发展机遇,促使众多工厂向智能…

作者头像 李华
网站建设 2026/6/5 10:40:10

HTTP 协议组成

一、概念HTTP 是一种应用层、基于请求–响应模型的无状态协议,由请求报文、响应报文以及传输规则组成。二、组成 HTTP 请求报文(Request) 请求行 请求头 空行 请求体(1)请求行 GET /index.html HTTP/1.1包含三部分&…

作者头像 李华
网站建设 2026/6/5 10:40:26

Part 12|模块要不要拆?新手也能用的一套判断方法

在做系统设计时,我们都会遇到一个问题:这个功能,要不要单独拆成一个模块?尤其是刚开始做项目的时候,很容易有一个想法:拆出来,看起来更专业一点。但实际情况往往是: 模块一多&#x…

作者头像 李华
网站建设 2026/6/9 19:43:38

英伟达调研600+从业者:AI医疗下一站从“影像领先”走向“虚拟助手+精准医疗”

【摘要】AI医疗正从影像诊断的单点突破,系统性地迈向以虚拟健康助手为入口、精准医疗为目标的生态整合新阶段。引言人工智能在医疗健康领域的渗透,早已不是新闻。从实验室的前沿探索到临床应用的逐步落地,这项技术正以前所未有的深度和广度重…

作者头像 李华
网站建设 2026/6/8 23:52:40

制砂机远程监控运维管理系统方案

制砂机作为矿山、建筑及道路工程中破碎与制砂作业的核心设备,其运行效率与稳定性直接关系到工程进度与产品质量。制砂机在工作过程中,涉及电机转速、进料量、出料粒度、振动强度及轴承温度等多个关键参数的实时监控与调节。 但传统运维方式依赖现场巡检与…

作者头像 李华