Langgraph_通过playwright mcp执行自动化

python 复制代码
from langchain_core.messages import HumanMessage
from langgraph.graph import StateGraph, START, END
from langgraph.graph.message import add_messages
from langchain_mcp_adapters.tools import load_mcp_tools
from mcp import ClientSession, StdioServerParameters
from mcp.client.stdio import stdio_client
from langchain_openai import ChatOpenAI
from typing import Annotated
from typing_extensions import TypedDict
from langgraph.prebuilt import ToolNode
import asyncio
import os
from dotenv import load_dotenv
'''
    执行脚本时需要确定api_key是否有效
'''
load_dotenv("../.env")
api_key = os.getenv("API_KEY")


# 定义状态
class MyState(TypedDict):
    messages: Annotated[list, add_messages]

# 定义 agent 结点
def agent(state: MyState) -> MyState:
    return {"messages": [model.invoke(state["messages"])]}

# LLM 是否调用工具
def is_call_tools(state: MyState) -> bool:
    last_message = state["messages"][-1]
    if last_message.tool_calls:
        return True
    return False

# 定义 mcp server 参数
mcp_server_param = [
    StdioServerParameters(
        command="npx",
        args=["@playwright/mcp@latest"],
        env=None
    )
]

# 声明模型
model = ChatOpenAI(
    model_name="Qwen3-Coder-Plus",  # deepseek-chat
    openai_api_key=api_key, # 填写 api-key
    openai_api_base="https://apis.iflow.cn/v1" # 填写 base-url,https://api.deepseek.com
)

async def main():
    try:
        async with stdio_client(mcp_server_param[0]) as (read, write):
            async with ClientSession(read, write) as session:
                # 绑定工具
                await session.initialize()
                tools = await load_mcp_tools(session)
                print("tools:", [tool.name for tool in tools])
                global model
                model = model.bind_tools(tools)

                # 定义图结构
                workflow = StateGraph(MyState)
                workflow.add_node("agent", agent)
                workflow.add_node("tools", ToolNode(tools=tools))
                workflow.add_edge(START, "agent")
                workflow.add_conditional_edges("agent", is_call_tools, {
                    True: "tools",
                    False: END
                })
                workflow.add_edge("tools", "agent")

                # 构建图
                graph = workflow.compile()
                # 调用图
                baidu_state = await graph.ainvoke({"messages": [HumanMessage("打开百度首页,然后搜索ai agent")]})
                print("Baidu result:", baidu_state['messages'][-1].content)

    except Exception as e:
        print(f"Error occurred: {e}")
        # Handle the exception gracefully


if __name__ == '__main__':
    asyncio.run(main())

说明: 执行脚本时若打开浏览器即关闭,出现 Error occurred: unhandled errors in a TaskGroup (1 sub-exception),则执行pip install playwright即可解决

复制代码
相关推荐
@atweiwei18 分钟前
langchainrust:Rust 版 LangChain 框架(LLM+Agent+RAG)
开发语言·rust·langchain·agent·向量数据库·rag
星马梦缘24 分钟前
强化学习实战7——用决策树打赢星际争霸II
人工智能·决策树·强化学习·deepmind·星际争霸·sc2
CoderJia程序员甲24 分钟前
GitHub 热榜项目 - 日榜(2026-04-11)
人工智能·ai·大模型·github·ai教程
ChatInfo25 分钟前
Etsy 把 1000 个 MySQL 分片迁进 Vitess:425TB 数据背后的真正问题不是性能,而是运维规模
数据库·人工智能·mysql
lifallen28 分钟前
Flink Agents:Python 执行链路与跨语言 Actor (PyFlink Agent)
java·大数据·人工智能·python·语言模型·flink
小二·29 分钟前
2026年4月技术热点深度解析:AI智能体攻防、量子安全与云原生新纪元
人工智能·安全·云原生
江瀚视野29 分钟前
京东健康综合门诊望京开业,京东医疗路在何方?
大数据·人工智能
飞凌嵌入式33 分钟前
如何用JishuShell在RK3588核心板上快速部署OpenClaw?
arm开发·人工智能·嵌入式硬件·openclaw
IT_陈寒33 分钟前
Vue的响应式更新把我坑惨了,原来是这个问题
前端·人工智能·后端
Tom·Ge34 分钟前
告别“猜谜式编程”!详解规范驱动开发(SDD)在企业AI开发中的最佳实践
人工智能·驱动开发