如何使用LangChain的Python库结合DeepSeek进行多轮次对话?

简介: 本文介绍如何使用LangChain结合DeepSeek实现多轮对话,测开人员可借此自动生成测试用例,提升自动化测试效率。

本文是基于LangChain的Python库结合DeepSeek进行多轮次对话;
对于测开人员来说,可以集成到自己的自动化测试框架中,自动生成测试用例。

首先看下LangChain的简单说明,大佬就不用看了。网上也有很多资料,这里简单说明下,针对没有基础的Tester。

1 关于LangChain

  • LangChain由Harrison Chase于2022年推出,提供了一套模块化工具和API(支持Python和JavaScript);
  • 是一个用于开发由大型语言模型(LLM)驱动的应用程序的开源框架;
  • 可简化从开发到生产的整个生命周期,支持与外部数据源、工具和服务的集成;
  • 其核心是通过标准化接口连接语言模型与外部组件(如数据存储、API等),降低开发复杂性和技术门槛。‌‌

1.1 应用场景

  • ‌智能代理与聊天机器人‌:支持上下文管理(如对话历史存储)和多工具集成,例如客服系统、虚拟助手等;
  • 文档处理与分析‌:通过检索增强生成(RAG)技术实现文档问答、摘要生成,结合向量数据库提升检索效率;
  • 自动化工作流‌:如代码生成、数据转换,利用链式调用(Chains)协调多个LLM完成任务;‌
  • 定制化提示工程‌:提供Prompt模板和输出解析器,控制模型响应格式(如JSON结构化输出)。

    1.2 ‌技术特点与案例‌

  • 模块化设计‌:包括Memory(上下文存储)、Embeddings(文本向量化)、Agents(代理决策)等组件,支持灵活组合;

  • 企业级应用‌:LinkedIn、Uber等公司使用LangChain构建生产级AI代理,处理复杂任务如订单处理、知识库查询;
  • 版本迭代‌:2025年发布的LangChain 1.0 Alpha进一步优化了代理架构和消息格式标准化,提升稳定性和兼容性。‌‌

2 本文写作目的

  • 基于LangChain的Python库结合DeepSeek进行多轮次对话;
  • 简单掌握其使用,便于在后续的自动化测试中应用。

3 学习过程

3.1 安装必要的库

pip install --upgrade langchain langchain-community deepseek python-dotenv

在这里插入图片描述

3.2 DeepSeek 官网注册

  • 进入官网,选择API开发平台,进行注册;

在这里插入图片描述

  • 注册后进行API密钥的获取。

    3.2 获取DeepSeek的API 密钥

  • 注册后,选择左侧的API keys:
    在这里插入图片描述
  • 点击创建API key:
    在这里插入图片描述
  • 输入名称:
    在这里插入图片描述
  • 复制API key后续加入到代码中就行了:
    在这里插入图片描述

    3.3 创建环境变量

  • 在项目的目录下,创建一个.env文件,如下:
    在这里插入图片描述
  • 输入自己的API key即可:
DEEPSEEK_API_KEY=你的API密钥

3.4 创建Py脚本使用LangChain调用DeepSeek模型

3.4.1 创建py文件

  • 我使用的是pycharm如下:
    在这里插入图片描述

    3.4.2 脚本设计思路

  • 初始化 DeepSeek 模型,设置 API 密钥和参数;
  • 创建对话提示模板,定义对话格式
  • 实现对话循环,支持连续交互。

3.4.3 引入依赖

  • 引入必要的依赖文件:
import os
from dotenv import load_dotenv
from langchain.chains import LLMChain
from langchain.prompts import ChatPromptTemplate
from langchain_community.llms import Deepseek

3.4.4 加载环境变量

  • 可以使用加载环境变量:
load_dotenv()

3.4.5 从环境变量获取DeepSeek API密钥

DEEPSEEK_API_KEY = os.getenv("DEEPSEEK_API_KEY")

3.4.6 创建带有记忆功能的DeepSeek对话链,支持多轮对话

"""创建带有记忆功能的DeepSeek对话链,支持多轮对话"""
    # 确认DeepSeek的API基础地址和模型名称
    llm = ChatOpenAI(
        model_name="deepseek-chat",
        openai_api_base="https://api.deepseek.com/v1",
        openai_api_key=DEEPSEEK_API_KEY,
        temperature=0.7,
        max_tokens=1024
    )

    # 创建对话提示模板
    prompt = PromptTemplate(
        input_variables=["history", "question"],
        template="历史对话: {history}\n用户现在的问题: {question}\n请根据历史对话内容,用简洁明了的语言回答:"
    )

    # 创建对话记忆
    memory = ConversationBufferMemory(memory_key="history")

    # 创建带有记忆功能的LLM链
    return LLMChain(
        llm=llm,
        prompt=prompt,
        memory=memory,
        verbose=False
    )

4 完整源码

import os
from dotenv import load_dotenv
from langchain.chains import LLMChain
from langchain.prompts import PromptTemplate
from langchain_community.chat_models import ChatOpenAI
from langchain.memory import ConversationBufferMemory
from langchain.schema import HumanMessage, AIMessage

# 加载环境变量
load_dotenv()

# 从环境变量获取DeepSeek API密钥
DEEPSEEK_API_KEY = os.getenv("DEEPSEEK_API_KEY")


def create_deepseek_chain_with_memory():
    """创建带有记忆功能的DeepSeek对话链,支持多轮对话"""
    # 确认DeepSeek的API基础地址和模型名称
    llm = ChatOpenAI(
        model_name="deepseek-chat",
        openai_api_base="https://api.deepseek.com/v1",
        openai_api_key=DEEPSEEK_API_KEY,
        temperature=0.7,
        max_tokens=1024
    )

    # 创建对话提示模板
    prompt = PromptTemplate(
        input_variables=["history", "question"],
        template="历史对话: {history}\n用户现在的问题: {question}\n请根据历史对话内容,用简洁明了的语言回答:"
    )

    # 创建对话记忆
    memory = ConversationBufferMemory(memory_key="history")

    # 创建带有记忆功能的LLM链
    return LLMChain(
        llm=llm,
        prompt=prompt,
        memory=memory,
        verbose=False
    )


def chat_with_deepseek():
    """与DeepSeek模型进行多轮对话"""
    print("DeepSeek对话助手(输入'退出'结束对话)")

    # 检查API密钥是否存在
    if not DEEPSEEK_API_KEY:
        print("错误: 未找到DEEPSEEK_API_KEY,请检查.env文件")
        return

    try:
        chain = create_deepseek_chain_with_memory()

        while True:
            user_input = input("\n你: ")

            if user_input.lower() == "退出":
                print("再见!")
                break

            try:
                response = chain.run(question=user_input)
                print(f"DeepSeek: {response}")
            except Exception as e:
                print(f"对话错误: {str(e)}")
    except Exception as e:
        print(f"初始化错误: {str(e)}")


if __name__ == "__main__":
    chat_with_deepseek()

5 问题排查

5.1 问题现象

  • DeepSeek API 调用失败,提示 “Insufficient Balance”(余额不足),但可能的原因不仅仅是账户余额问题,还可能是 API 配置错误(比如错误地使用了 OpenAI 的 SDK 但未正确指向 DeepSeek 的 API)。

5.2 解决方法

  • 确保使用的是 DeepSeek 的 API,而不是 OpenAI

DeepSeek 的 API 和 OpenAI 的 API 不兼容,如果你直接使用 openai 库但未修改 base_url,就会默认调用 OpenAI 的接口,导致 402 错误(OpenAI 的 API 需要付费)。
正确调用 DeepSeek API 的方式:

from openai import OpenAI

# 使用 DeepSeek 的 API 地址和你的 API Key
client = OpenAI(
    api_key="your_deepseek_api_key_here",  # 替换成你的 DeepSeek API Key
    base_url="https://api.deepseek.com/v1",  # DeepSeek 的 API 地址
)

response = client.chat.completions.create(
    model="deepseek-chat",  # 检查 DeepSeek 支持的最新模型名称
    messages=[{
   "role": "user", "content": "你好!"}],
    temperature=0.3,
)

print(response.choices[0].message.content)

关键点:

base_url 必须指向 DeepSeek 的 API 地址(如 https://api.deepseek.com/v1)。
api_key 必须是 DeepSeek 提供的 API Key(不是 OpenAI 的 Key)。 model 要使用 DeepSeek
支持的模型(如 deepseek-chat)。

  • 检查你的 DeepSeek API 余额

即使 DeepSeek 提供免费额度,也可能:

免费额度已用完(比如每月限额)。 未正确申请 API 权限(部分 API 需要申请白名单)。

目录
相关文章
|
2月前
|
监控 数据可视化 数据挖掘
Python Rich库使用指南:打造更美观的命令行应用
Rich库是Python的终端美化利器,支持彩色文本、智能表格、动态进度条和语法高亮,大幅提升命令行应用的可视化效果与用户体验。
171 0
|
7月前
|
JavaScript 前端开发 Java
通义灵码 Rules 库合集来了,覆盖Java、TypeScript、Python、Go、JavaScript 等
通义灵码新上的外挂 Project Rules 获得了开发者的一致好评:最小成本适配我的开发风格、相当把团队经验沉淀下来,是个很好功能……
1292 103
|
4月前
|
存储 Web App开发 前端开发
Python + Requests库爬取动态Ajax分页数据
Python + Requests库爬取动态Ajax分页数据
|
1月前
|
数据可视化 关系型数据库 MySQL
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
本文详解基于Python的电影TOP250数据可视化大屏开发全流程,涵盖爬虫、数据存储、分析及可视化。使用requests+BeautifulSoup爬取数据,pandas存入MySQL,pyecharts实现柱状图、饼图、词云图、散点图等多种图表,并通过Page组件拖拽布局组合成大屏,支持多种主题切换,附完整源码与视频讲解。
164 4
【可视化大屏】全流程讲解用python的pyecharts库实现拖拽可视化大屏的背后原理,简单粗暴!
|
1月前
|
传感器 运维 前端开发
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
本文解析异常(anomaly)与新颖性(novelty)检测的本质差异,结合distfit库演示基于概率密度拟合的单变量无监督异常检测方法,涵盖全局、上下文与集体离群值识别,助力构建高可解释性模型。
265 10
Python离群值检测实战:使用distfit库实现基于分布拟合的异常检测
|
3月前
|
运维 Linux 开发者
Linux系统中使用Python的ping3库进行网络连通性测试
以上步骤展示了如何利用 Python 的 `ping3` 库来检测网络连通性,并且提供了基本错误处理方法以确保程序能够优雅地处理各种意外情形。通过简洁明快、易读易懂、实操性强等特点使得该方法非常适合开发者或系统管理员快速集成至自动化工具链之内进行日常运维任务之需求满足。
192 18
|
4月前
|
JSON 网络安全 数据格式
Python网络请求库requests使用详述
总结来说,`requests`库非常适用于需要快速、简易、可靠进行HTTP请求的应用场景,它的简洁性让开发者避免繁琐的网络代码而专注于交互逻辑本身。通过上述方式,你可以利用 `requests`处理大部分常见的HTTP请求需求。
413 51
|
3月前
|
机器学习/深度学习 API 异构计算
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
JAX是Google开发的高性能数值计算库,旨在解决NumPy在现代计算需求下的局限性。它不仅兼容NumPy的API,还引入了自动微分、GPU/TPU加速和即时编译(JIT)等关键功能,显著提升了计算效率。JAX适用于机器学习、科学模拟等需要大规模计算和梯度优化的场景,为Python在高性能计算领域开辟了新路径。
309 0
JAX快速上手:从NumPy到GPU加速的Python高性能计算库入门教程
|
3月前
|
数据采集 存储 Web App开发
Python爬虫库性能与选型实战指南:从需求到落地的全链路解析
本文深入解析Python爬虫库的性能与选型策略,涵盖需求分析、技术评估与实战案例,助你构建高效稳定的数据采集系统。
333 0
|
3月前
|
存储 监控 安全
Python剪贴板监控实战:clipboard-monitor库的深度解析与扩展应用
本文介绍了基于Python的剪贴板监控技术,结合clipboard-monitor库实现高效、安全的数据追踪。内容涵盖技术选型、核心功能开发、性能优化及实战应用,适用于安全审计、自动化办公等场景,助力提升数据管理效率与安全性。
147 0

推荐镜像

更多