langchain使用

安装需要包

bash 复制代码
pip install langchain langchain-deepseek python-dotenv

工作流

bash 复制代码
from langchain_core.prompts import ChatPromptTemplate
from langchain_core.output_parsers import StrOutputParser
from langchain_deepseek import ChatDeepSeek
import os

# 配置密钥+模型
os.environ["DEEPSEEK_API_KEY"] = "sk-"
llm = ChatDeepSeek(
    model="deepseek-v4-pro",
    temperature=0.2,
    max_tokens=2048,
    streaming=True  # 流式已开启
)
parser = StrOutputParser()

# ========== 定义4个工作流节点 ==========
prompt_analyse = ChatPromptTemplate.from_messages([
    ("system", "资深后端工程师,精准拆解开发需求,梳理实现思路"),
    ("user", "需求内容:{user_task}")
])
chain_analyse = prompt_analyse | llm | parser

prompt_code = ChatPromptTemplate.from_messages([
    ("system", "根据需求思路编写完整可运行代码,规范整洁"),
    ("user", "需求思路:{analyse_result}")
])
chain_code = prompt_code | llm | parser

prompt_optimize = ChatPromptTemplate.from_messages([
    ("system", "优化代码性能、可读性、异常处理,精简冗余逻辑"),
    ("user", "原始代码:{code_result}")
])
chain_optimize = prompt_optimize | llm | parser

prompt_summary = ChatPromptTemplate.from_messages([
    ("system", "简短总结功能用途、使用方式、注意事项"),
    ("user", "优化后代码:{optimize_result}")
])
chain_summary = prompt_summary | llm | parser

# ========== 流式输出工具函数 ==========
def stream_output(chain, input_data):
    result = ""
    for chunk in chain.stream(input_data):
        print(chunk, end="", flush=True)
        result += chunk
    print("\n")
    return result

# ========== 流式工作流 ==========
def run_workflow(user_task: str):
    print("===== 1.需求解析中 =====\n")
    analyse_res = stream_output(chain_analyse, {"user_task": user_task})

    print("===== 2.生成代码中 =====\n")
    code_res = stream_output(chain_code, {"analyse_result": analyse_res})

    print("===== 3.代码优化中 =====\n")
    optimize_res = stream_output(chain_optimize, {"code_result": code_res})

    print("===== 4.最终总结 =====\n")
    summary_res = stream_output(chain_summary, {"optimize_result": optimize_res})

    return summary_res

# 执行
if __name__ == "__main__":
    task = "用Python写一个文件批量重命名工具"
    run_workflow(task)

搭配mcp操作文件

bash 复制代码
from langchain_core.prompts import ChatPromptTemplate
from langchain_core.output_parsers import StrOutputParser
from langchain_openai import ChatOpenAI  # 用这个,不用 langchain_deepseek
from langchain_core.tools import tool
import os

# ===================== 配置 =====================
os.environ["DEEPSEEK_API_KEY"] = "sk-"

# ✅ 关键:用 ChatOpenAI 调用 DeepSeek,永不报错
llm = ChatOpenAI(
    model="deepseek-v4-pro",
    api_key=os.environ["DEEPSEEK_API_KEY"],
    base_url="https://api.deepseek.com",
    temperature=0.2,
    max_tokens=4096,
    streaming=True
)
parser = StrOutputParser()

# ===================== MCP 工具(无依赖冲突) =====================
@tool
def mcp_create_file(file_path: str, content: str) -> str:
    """MCP 文件创建工具"""
    try:
        with open(file_path, "w", encoding="utf-8") as f:
            f.write(content)
        return f"[MCP] 文件已保存:{file_path}"
    except Exception as e:
        return f"[MCP] 错误:{str(e)}"

# ===================== 工作流 =====================
prompt_analyse = ChatPromptTemplate.from_messages([
    ("system", "资深后端工程师,精准拆解开发需求,梳理实现思路"),
    ("user", "需求内容:{user_task}")
])
chain_analyse = prompt_analyse | llm | parser

prompt_code = ChatPromptTemplate.from_messages([
    ("system", "根据需求思路编写完整可运行代码,规范整洁"),
    ("user", "需求思路:{analyse_result}")
])
chain_code = prompt_code | llm | parser

prompt_optimize = ChatPromptTemplate.from_messages([
    ("system", "优化代码性能、可读性、异常处理"),
    ("user", "原始代码:{code_result}")
])
chain_optimize = prompt_optimize | llm | parser

prompt_summary = ChatPromptTemplate.from_messages([
    ("system", "总结功能,并自动保存代码"),
    ("user", "优化后代码:{optimize_result}")
])
chain_summary = prompt_summary | llm | parser

# ===================== 流式输出 =====================
def stream_output(chain, input_data):
    result = ""
    for chunk in chain.stream(input_data):
        print(chunk, end="", flush=True)
        result += chunk
    print("\n")
    return result

# ===================== 工作流执行 =====================
def run_workflow(user_task: str):
    print("===== 1.需求解析中 =====\n")
    analyse_res = stream_output(chain_analyse, {"user_task": user_task})

    print("===== 2.生成代码中 =====\n")
    code_res = stream_output(chain_code, {"analyse_result": analyse_res})

    print("===== 3.代码优化中 =====\n")
    optimize_res = stream_output(chain_optimize, {"code_result": code_res})

    print("===== 4.最终总结 + 自动保存文件 =====\n")
    summary_res = stream_output(chain_summary, {"optimize_result": optimize_res})

    # 自动保存
    print(mcp_create_file.invoke({"file_path": "output_code.py", "content": optimize_res}))
    return summary_res

if __name__ == "__main__":
    task = "写个漂亮的登录页面,html"
    run_workflow(task)
相关推荐
像我这样帅的人丶你还1 小时前
Java 后端详解(四):分页与搜索
java·javascript·后端
她的男孩1 小时前
数据权限为什么不能只靠注解?Forge 的 Mapper 层 SQL 改写源码拆解
java·后端·架构
tntxia2 小时前
Mybatis的日志输入
java
亦暖筑序3 小时前
Java 8老系统Browser Agent实战:三层拦截把AI操作后台变成可审计流程
java·后端·设计模式
ZhengEnCi5 小时前
P2M-Matplotlib折线图完全指南-从数据可视化到趋势分析的Python绘图利器
python·matlab·数据可视化
用户298698530146 小时前
Java 实现 Word 文档加密与权限解除
java·后端
ZhengEnCi7 小时前
P2L-Matplotlib饼图完全指南-从数据可视化到图表定制的Python绘图利器
python·matlab
曲幽7 小时前
你的REST接口还在“过度投喂”数据吗?——FastAPI + GraphQL实战避坑指南
python·fastapi·web·graphql·route·cors·rest·strawberry
Yeats_Liao7 小时前
14:Servlet中的页面跳转-Java Web
java·后端·架构
未秃头的程序猿7 小时前
告别"if-else地狱"!Java 21模式匹配,代码优雅了10倍
java·后端·面试