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 小时前
SolonCode CLI 的心智记忆功能:让 AI 编程助手越用越懂你
java·ai·llm·cli·soloncode
BU摆烂会噶1 小时前
【LangGraph】作为节点添加与状态共享
android·人工智能·python·ui·langchain·人机交互
hughnz1 小时前
钻井“自动化”的终点就是钻井自主化的起点
运维·数据库·python
常常有1 小时前
AI智能知识库问答系统(基于 FastAPI和Dify)
python·mysql·fastapi
CLX05051 小时前
CSS如何制作响应式图片集布局_利用object-fit填充空间
jvm·数据库·python
我命由我123451 小时前
Visual Studio - Visual Studio 注释快捷键
java·c语言·开发语言·c++·ide·java-ee·visual studio
平常心cyk2 小时前
Dify和Function Calling(函数调用)简介
python
lemon_sjdk2 小时前
DecimalFormat
java·开发语言·python
2303_821287382 小时前
SQL如何进行分组后字符串拼接_使用GROUP_CONCAT或STRING_AGG
jvm·数据库·python