在Coze上新建一个插件

简介

本文介绍如何在 Coze 上新建一个自己定义的插件,关于 Coze 智能体的使用,参看前文:

创建插件

第一步:新建插件

点击"资源库",点击右上角的"插件",选择"插件"。

第二步:填写插件信息

在弹出的这个窗口中,填写插件相关的信息,最底下 IDE 环境,可根据自身需要选择,我这选择 Python3。

第三步:创建工具

插件创建完成,创建工具。

相当于创建一个方法,具有某种具体用途,可以完成某种目的。

如下,编写工具详细。

第四步:实现工具

在下面这个界面中,完成工具的参数设置,代码实现和调试。

先点中间的"元数据",定义入参和返回。

返回,编写代码,当然是大模型生成的,我用的千问,代码如下:

python 复制代码
from runtime import Args
from typings.get_result.get_result import Input, Output
import re

def calculate_expression(expr: str) -> float:
    """
    安全计算仅包含 +, -, *, / 的算术表达式。
    要求:
        - 数字:整数部分 ≤ 10000,小数最多两位
        - 无空格,仅含数字、.、+、-、*、/
    """
    if not expr.strip():
        raise ValueError("表达式为空")
    
    # 检查非法字符(只允许数字、运算符、小数点)
    if not re.fullmatch(r'[0-9+\-*/.]+', expr):
        raise ValueError("表达式包含非法字符")
    
    # 提取所有数字(包括负数)
    tokens = re.findall(r'-?\d+(?:\.\d{1,2})?', expr)
    if not tokens:
        raise ValueError("未找到有效数字")
    
    # 验证每个数字格式
    for token in tokens:
        try:
            num = float(token)
            if abs(int(num)) > 10000:
                raise ValueError(f"数字 {num} 整数部分超过 10000")
            if '.' in token:
                decimal_part = token.split('.')[1]
                if len(decimal_part) > 2:
                    raise ValueError(f"数字 {num} 小数位数超过两位")
        except ValueError as e:
            if "could not convert" in str(e):
                raise ValueError(f"无效数字: {token}")
            else:
                raise
    
    # 安全计算
    try:
        result = eval(expr, {"__builtins__": {}}, {})
        return float(result)
    except ZeroDivisionError:
        raise ValueError("除数不能为零")
    except Exception as e:
        raise ValueError(f"表达式语法错误: {e}")


def handler(args: Args[Input]) -> Output:
    """
    平台入口函数:接收 args.input.expr,返回计算结果或错误信息。
    """
    expr = args.input.expr  # 从输入中获取表达式字符串
    
    try:
        result = calculate_expression(expr)
        # 假设 Output 定义为 { "result": number }
        return {"result": result}
    except Exception as e:
        # 如果平台允许 error 字段,可返回;否则可能需要抛异常
        # 这里按常见做法:返回 error 字段(需确认 Metadata 是否包含)
        # 若 Metadata 只有 result,则应抛异常让平台捕获
        # 保守起见,我们抛出异常(平台会捕获并转为错误)
        raise RuntimeError(f"计算失败: {str(e)}")

在右侧进行调试。

如果需要安装一些 python 库,可以在左侧搜索安装。

发布

调试完成,点右上角的"发布"。

继续,点"发布。

制作完成

相关推荐
Ray Liang1 小时前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮1 小时前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling1 小时前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python
程序员鱼皮3 小时前
又一个新项目完结,我要出海了!
ai·github·开源项目
AI攻城狮4 小时前
用 Playwright 实现博客一键发布到稀土掘金
python·自动化运维
曲幽5 小时前
FastAPI分布式系统实战:拆解分布式系统中常见问题及解决方案
redis·python·fastapi·web·httpx·lock·asyncio
孟健20 小时前
Karpathy 用 200 行纯 Python 从零实现 GPT:代码逐行解析
python
码路飞21 小时前
写了个 AI 聊天页面,被 5 种流式格式折腾了一整天 😭
javascript·python
GPUStack1 天前
Token 不再焦虑:用 GPUStack + OpenClaw 搭一个“无限用”的本地 AI 助手
ai·模型推理·gpustack·openclaw