logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

作用

让Agent开发更顺手的工具集合

安装

https://docs.langchain.com/oss/python/integrations/providers/overview

# 主要依赖
uv add langchain
# 对应的模型依赖
uv add langchain-openai
uv add langchain-deepseek
uv add langchain-ollama

基础代码

import os
from langchain.chat_models import init_chat_model

# 方式1:直接设置 Key(测试用)
os.environ["DEEPSEEK_API_KEY"] = "sk-xxx"

# 方式2:使用 .env 文件(推荐,需先安装 python-dotenv)
# from dotenv import load_dotenv
# load_dotenv()  # 自动读取 .env 文件中的 DEEPSEEK_API_KEY

# 初始化模型
model = init_chat_model(
    model="deepseek-chat",           # 使用的模型名称
    model_provider="deepseek",       # 指定提供商为 deepseek
    temperature=0.7                  # 可选:控制随机性
)

# 调用模型
response = model.invoke("你好,请介绍一下你自己")
print(response.content)

或ollama

from langchain.chat_models import init_chat_model

model = init_chat_model(
    model="qwen3.5:4b",           # 你的 Ollama 模型名
    model_provider="ollama",     # 指定提供商为 ollama
    temperature=0.7              # temperature 参数同样适用
)

# 调用模型,这部分代码完全不用变
response = model.invoke("你好,请介绍一下你自己")
print(response.content)

流式调用

from langchain.chat_models import init_chat_model

model = init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7
)

# 使用 stream() 方法进行流式输出
for chunk in model.stream("你好,请介绍一下你自己"):
    print(chunk.content, end="", flush=True)  # end="" 避免换行,flush=True 实时输出

思考内容

from langchain.chat_models import init_chat_model

model = init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7,
    reasoning=True  # 🔑 关键参数:开启思考模式
)

# 流式输出时,思考内容会被分离到 additional_kwargs 中
for chunk in model.stream("请问 1+1=?中文交流"):
    # 打印思考内容(如果存在)
    reasoning = chunk.additional_kwargs.get("reasoning_content")
    if reasoning:
        print(f"{reasoning}", end="", flush=True)

    # 打印正式回答
    if chunk.content:
        print(chunk.content, end="", flush=True)

智能体

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model

agent = create_agent(init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7,
))

response = agent.invoke({
    "messages": [
        {
            "role": "user",
            "content": "你好呀"
        }
    ]
})

print(response)

或流式

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model

agent = create_agent(init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7,
))

messages = agent.stream(
    {
        "messages": [
            {
                "role": "user",
                "content": "你好呀"
            }
        ],
    },
    stream_mode="messages"
)

"""
模式	             正确写法	       用途
LLM Tokens	     "messages"	   逐 token 流式输出,实现打字机效果
Agent Progress	 "updates"	   监控每个 agent step 后的状态更新
Values	         "values"	   获取每个 step 后的完整状态
Custom	         "custom"	   自定义事件
"""

for token, metadata in messages:
    if token.content:
        print(token.content, end="", flush=True)

消息类型

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model
from langchain_core.messages import SystemMessage, HumanMessage, AIMessage, ToolMessage

agent = create_agent(init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7,
))

response = agent.invoke(
    {
        "messages": [
            SystemMessage(content="请使用中文交流"),
            HumanMessage(content="你好呀")
        ],
    }
)

for message in response['messages']:
    message.pretty_print()

多模态

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model
from langchain_core.messages import SystemMessage, HumanMessage, AIMessage, ToolMessage
import base64


# 图片转base64
def encode_image(image_path):
    with open(image_path, 'rb') as image_file:
        bin_content = image_file.read()
        return base64.b64encode(bin_content).decode("utf-8")


agent = create_agent(init_chat_model(
    model="qwen3.5:4b",
    model_provider="ollama",
    temperature=0.7,
))

response = agent.invoke(
    {
        "messages": [
            SystemMessage(content="请使用中文交流"),
            HumanMessage(content=[
                {
                    "type": "image",
                    "base64": encode_image("22.png"),
                    "mime_type": "image/png",
                },
                {
                    "type": "text",
                    "text": "图片中有什么?"
                }
            ])
        ],
    }
)

for message in response['messages']:
    message.pretty_print()

系统提示词

因为是固定的,每次对话都有,使用在创建智能体的时候加入才合适

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model
from langchain_core.messages import SystemMessage, HumanMessage, AIMessage, ToolMessage

agent = create_agent(
    init_chat_model(
        model="qwen3.5:4b",
        model_provider="ollama",
        temperature=0.7,
    ),
    system_prompt="请使用中文交流"
)

response = agent.invoke(
    {
        "messages": [
            HumanMessage(content="你好呀")
        ],
    }
)

for message in response['messages']:
    message.pretty_print()

结构化输出

# 智能体
from langchain.agents import create_agent
from langchain.chat_models import init_chat_model
from langchain_core.messages import SystemMessage, HumanMessage, AIMessage, ToolMessage
from pydantic import BaseModel


class DemoTemp(BaseModel):
    name: str
    age: int


agent = create_agent(
    init_chat_model(
        model="qwen3.5:4b",
        model_provider="ollama",
        temperature=0.7,
    ),
    system_prompt="请使用中文交流",
    response_format=DemoTemp # 指定
)

response = agent.invoke(
    {
        "messages": [
            HumanMessage(content="给我3个人")
        ],
    }
)

for message in response['messages']:
    message.pretty_print()

工具调用

from langchain.agents import create_agent
from langchain.chat_models import init_chat_model
from langchain_core.messages import SystemMessage, HumanMessage, AIMessage, ToolMessage
from langchain_core.tools import tool


@tool
def get_weather():
    """获取当前的天气情况"""
    return "贵阳今日温度28摄氏度"


agent = create_agent(
    init_chat_model(
        model="qwen3.5:4b",
        model_provider="ollama",
        temperature=0.7,
    ),
    tools=[get_weather]
)

response = agent.invoke(
    {
        "messages": [
            HumanMessage(content="今天天气如何?")
        ],
    }
)

for message in response['messages']:
    message.pretty_print()
作用
安装
基础代码
流式调用
思考内容
智能体
消息类型
多模态
系统提示词
结构化输出
工具调用