当前位置: 首页 > news >正文

最简单的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)
http://www.cnnetsun.cn/news/114420.html

相关文章:

  • 空压机监控运维管理系统方案
  • 实习面试题-Rust 面试题
  • 视频字幕精确生成方法 用到字幕api开发文档
  • React Fiber 架构解析:如何利用 `requestIdleCallback` 实现时间切片(Time Slicing)
  • SPA 应用中的路由切换内存泄漏:未注销的 Scroll 监听与全局变量
  • 游泳池漆专用施工涂料如何选?专业视角解析耐水抗氯性能
  • 中国RFID设备十大企业综合实力解析
  • C#静态成员总结 常量与只读字段总结 类的继承总结
  • 都说东莞有好的AI销售厂家,实际情况真如此吗?
  • Python开发者必看:一行代码切换GPT-5.2与DeepSeek V3.2,企业级大模型中台搭建实录
  • 浏览器代理实现理想数据抓取
  • LeetCode 01 背包 完全背包 题型总结
  • ubuntu通过公网Ubuntu服务器远程桌面连接私网IPUbuntu
  • Unity学习笔记(十九)GUI控件(三)
  • IPA 深度混淆是什么意思?分析其与普通混淆的区别
  • 33、Linux 内存管理全解析
  • 5.回溯算法
  • 嵌入式模组温控策略
  • 【昇腾CANN训练营·架构篇】打破内存墙:Ascend C 算子融合(Operator Fusion)的极致心法
  • 【昇腾CANN训练营·算法篇】寻找消失的除法器:Newton Iteration 与高精度数学计算的艺术
  • 19、Linux 帧缓冲接口设计与图形库应用
  • 人才发展ℓℓ 人才盘点怎么做?这篇完全应用手册给出答案
  • 真相来了|字节跳动的人才真相:真正拉开差距的,是“人才密度”(附人才密度清单)
  • 力扣(LeetCode) 66: 加一 - 解法思路
  • HC32L130精准延时实现指南
  • 收藏必看!大学生网络安全学习5大方向,校招不踩坑,小白也能逆袭!
  • 收藏!从“黑客梦“到网络安全专家:过来人告诉你自学路线图
  • Bagisto 产品更新后,前台默认语言的内容不更信,其他语言正常。
  • 【收藏】运维转网安的黄金路径:4个高适配岗位+3步落地指南,薪资提升50%
  • 大语言模型全解析:一篇文章带你深入理解AI的强大能力!