Agent

B站视频链接:https://www.bilibili.com/video/BV1aeLqzUE6L?spm_id_from=333.788.videopod.sections\&vd_source=0a100cb9d25855cbc65bcb483a8a5a84

  • user prompt: 我们通过聊天框发送给AI模型的消息;
  • system prompt: 用来描述AI的角色、性格、背景信息、语气等;

每次用户发送user prompt的时候,系统会自动把system prompt发送给AI

  • function calling: 规定了AI使用工具时应该返回的格式;
  • MCP: 是一个通信协议,专门用来规范Agent和Tool服务之间是怎么交互的,称Tool服务为MCP server,调用它的Agent为MCP client,MCP实际上用来帮助Agent管理工具、资源和提示词;

MCP server可以和Agent部署在一起,通过stdio标准输入输出来通信,也可以部署在远程,通过HTTP网络协议来访问;

B站视频链接:https://www.bilibili.com/video/BV1UMVKzEESL?spm_id_from=333.788.videopod.sections\&vd_source=0a100cb9d25855cbc65bcb483a8a5a84

需要准备的:

  • 一个Gemini模型的API KEY

  • 一个Python环境

  • 安装必要的Python库:pydantic_ai, dotenv

  • 一个.env文件,用来存储API KEY

  • 一个Agent_demo目录,用来存放Agent的代码

    • main.py: 用来运行Agent的代码
    • tools.py: 用来定义Agent可以调用的工具函数
    • .env: 用来存储API KEY
    • base_dir: 用来存储Agent可以访问的文件目录

    main.py

python 复制代码
from pydantic_ai.models.gemini import GeminiModel
from pydantic_ai import Agent

from dotenv import load_dotenv # 加载.env文件中的API KEY
import tools

load_dotenv()
model = GeminiModel("gemini-2.5-flash-preview-04-17")

agent = Agent(model,
             system_prompt="You are an experienced programmer",
             tools=[tools.read_file, tools.list_files, tools.rename_file])

def main():
   history = []
   while True:
       user_input = input("Input: ") # 通过标准输入接收用户的鹅指令
       resp = agent.run_sync(user_input,
                             message_history=history) # 将用户输入和历史记录直接传给Agent
       history = list(resp.all_messages()) # 保留聊天记录
       print(resp.output)  # 打印AI的返回结果


if __name__ == "__main__":
   main()

tools.py

python 复制代码
from pathlib import Path
import os

base_dir = Path("./test")

# 读文件
def read_file(name: str) -> str:
    """Return file content. If not exist, return error message.
    """
    print(f"(read_file {name})")
    try:
        with open(base_dir / name, "r") as f:
            content = f.read()
        return content
    except Exception as e:
        return f"An error occurred: {e}"
# 列目录
def list_files() -> list[str]:
    print("(list_file)")
    file_list = []
    for item in base_dir.rglob("*"):
        if item.is_file():
            file_list.append(str(item.relative_to(base_dir)))
    return file_list
# 改文件名
def rename_file(name: str, new_name: str) -> str:
    print(f"(rename_file {name} -> {new_name})")
    try:
        new_path = base_dir / new_name
        if not str(new_path).startswith(str(base_dir)):
            return "Error: new_name is outside base_dir."

        os.makedirs(new_path.parent, exist_ok=True)
        os.rename(base_dir / name, new_path)
        return f"File '{name}' successfully renamed to '{new_name}'."
    except Exception as e:
        return f"An error occurred: {e}"
相关推荐
染指11107 分钟前
9.LangChain框架(实现RAG)
数据库·人工智能·算法·机器学习·ai·大模型
福老板的生意经8 分钟前
AI 短视频全链路创作分发系统架构解析:模块化设计与核心技术实现
人工智能·系统架构·音视频
AI医影跨模态组学9 分钟前
如何将影像组学与病理组学特征与胃癌术后复发的“炎症‑耗竭”免疫机制建立关联,并解释其与患者预后及辅助化疗/免疫治疗响应的机制联系
人工智能·深度学习·论文·医学影像·影像组学
我爱cope14 分钟前
【Agent智能体5 | 任务分解:识别工作流中的步骤】
人工智能·职场和发展
shen_15 分钟前
Skill:Agent 的能力扩展系统
人工智能·agent
alwaysrun16 分钟前
AI之发展启示(The Bitter Lesson)
人工智能·aigc
小明与核桃20 分钟前
从 Prompt 到 Context 再到 Harness:AI 工程化的三次进化
人工智能
北京耐用通信21 分钟前
耐达讯自动化:专业解决MODBUS TCP转PROFIBUS协议转换难题
人工智能·物联网·网络协议·自动化·信息与通信
java1234_小锋22 分钟前
利用Cursor AI编程 两小时实现 基于Spring AI 2.0的带智能客服的商城系统(带在线支付功能)
人工智能·spring·ai编程·智能客服·spring ai·ai智能客服
图特摩斯科技33 分钟前
AI自动构建本体?安排! Harness+OntoFlow让本体开发像搭积木一样简单
人工智能·知识图谱·abutiongraph·本体论·palantir·ontology