使用Python写一个适用于Dify和FastGPT的JsonPath插件

news/2024/9/20 4:45:44/ 标签: python, 开发语言

编写适用于 Dify 和 FastGPT 的 JsonPath 插件

在本文中,我将分享如何编写一个适用于 AI应用平台的 JsonPath 插件,该插件能够处理 JSON 数据的路径查询、正则表达式提取,以及 JavaScript 沙盒执行功能。这个插件的主要目的是让用户能够通过简单的 HTTP 请求,对 JSON 数据进行高效、灵活的查询和处理。接下来,我们将详细介绍如何实现这个插件的功能。

项目结构与依赖

首先,我们需要创建一个 Flask 应用程序来承载这个插件。项目的主要依赖项包括 Flaskjsonpath_ngrejsonjs2pythreading。这些库分别用于处理 HTTP 请求、JSONPath 查询、正则表达式匹配、JavaScript 代码执行和处理并发任务。

python">from flask import Flask, request, jsonify
from jsonpath_ng import parse
import re
import json
import js2py
import threading
import logging

为了便于调试和跟踪,我们配置了日志记录功能:

python">logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')
JSONPath 查询

首先,我们实现了一个 JSONPath 查询功能,通过 POST 请求获取用户提交的 JSONPath 表达式和 JSON 数据,并返回匹配的结果。

python">@app.route('/jsonpath', methods=['POST'])
def get_value_by_jsonpath():json_path = request.json.get('json_path')json_string = request.json.get('json_string')data = json.loads(json_string)jsonpath_expr = parse(json_path)matches = [match.value for match in jsonpath_expr.find(data)]if '*' in json_path or ('[' in json_path and ':' in json_path):return jsonify({"data": matches})  # 预期返回列表else:if len(matches) == 0:return jsonify({"data": None})else:return jsonify({"data": matches[0]}) if matches else None  # 预期返回单个元素
正则表达式提取

接下来,我们实现了一个正则表达式提取功能,用户可以通过提交正则表达式和目标字符串来提取匹配的内容。

python">@app.route('/regex_extract', methods=['POST'])
def regex_extract():regex = request.json.get('regex')string = request.json.get('string')if not regex or not string:return jsonify({"error": "regex或string参数不正确"}), 400result = extract_target(regex, string)logging.info('regex: %s, string: %s, result: %s', regex, string, result)return jsonify({"data": result, "match": True if result else False})
JavaScript 沙盒执行

最后,我们实现了一个 JavaScript 沙盒执行功能,允许用户提交 JavaScript 代码,并在一个安全的环境中执行该代码。我们使用 js2py 库来执行 JavaScript,并设置了超时机制以防止脚本长时间运行。

python">@app.route('/js_sandbox', methods=['POST'])
def js_sandbox():code = request.json.get('code')if not code:return jsonify({"error": "code参数不正确"}), 400code = fix_string_conflicts(code)timer = threading.Timer(3.0, timeout)timer.start()result = Nonetry:result = js2py.eval_js(code)print(result)except Exception as e:logging.error("Error while executing JavaScript: %s", e)finally:timer.cancel()logging.info('code: %s, result: %s', code, result)return jsonify({"data": result})

总结

通过上述步骤,我们实现了一个简单但功能强大的 JsonPath 插件,适用于 Dify 和 FastGPT。它可以处理 JSONPath 查询、正则表达式提取以及 JavaScript 沙盒执行等任务。希望这篇文章能帮助你更好地理解如何构建类似的插件,并将其应用到你的项目中。如果你有任何问题或建议,欢迎在评论区留言讨论。


http://www.ppmy.cn/news/1520471.html

相关文章

kubeadm方式升级k8s集群

一、注意事项 升级前最好备份所有组件及数据,例如etcd 不要跨两个大版本进行升级,可能会存在版本bug,如: 1.19.4–>1.20.4 可以 1.19.4–>1.21.4 不可以 跨多个版本的可以逐个版本进行升级。 二、查看当前版本 [rootk8s…

8逻辑回归的代价函数

8.1逻辑回归中的代价函数 成本函数 损失函数 8.2逻辑回归的简化版代价函数 代价函数的简化 损失函数的简化 方框内的式子等于上面的

Cadence Virtuoso添加工艺库、转换工艺库格式

系统环境:Red Hat 操作软件:Virtuoso 工艺库:tsmc18rf 1、准备好工艺库文件,放在任意文件夹内,记住文件路径: 2、打开Virtuoso软件: 在桌面右键打开终端,输入: virtuo…

Oracle SQL和PL/SQL中SQL%ROWCOUNT和SQL%FOUND属性

在Oracle SQL和PL/SQL中,SQL%ROWCOUNT和SQL%FOUND是两个常用的属性,它们各自在不同的上下文中提供关于最近执行的DML(数据操纵语言)语句(如INSERT、UPDATE、DELETE)或SELECT INTO语句的反馈信息。尽管这两个…

Scott Brinker:Martech中的AI会让买家体验更好还是更糟?这取决于…….

Martech中的AI会让买家体验更好还是更糟? 你怎么知道自己正处于炒作周期的顶峰?当手段大于目的。 Martech专业人士和营销运营领导者正被推动将人工智能应用于营销——将其用于任何事情!——相信人工智能的自动化和加速,尤其是生…

AI 大模型在文本生成任务中的创新应用

概述 随着人工智能技术的飞速发展,大模型在文本生成任务中的应用越来越广泛。这些模型通过深度学习技术,能够生成连贯、有意义的文本,甚至在某些情况下达到与人类写作难以区分的程度。本文将探讨AI大模型在文本生成任务中的创新应用&#xf…

zsh 的补全系统

在 Zsh 中,自动提醒(自动补全)功能通常由 zsh 的补全系统(zsh-completions)和 zsh-autosuggestions 等插件提供。如果你的 Zsh 不再自动提醒了,可以通过以下步骤来检查和启用这些功能。 1. 确保补全系统已…

Azure OpenAI Ingesion Job API returns 404 Resource not found

题意:Azure OpenAI Ingestion Job API 返回 404 资源未找到。 问题背景: Im following the documentation from Azure on the ingestion job API here: Ingestion Jobs - Create - REST API (Azure Azure AI Services) | Microsoft Learn 我正在按照Az…

数据分析有哪些流程?

‌数据分析的流程主要包括明确目的、数据收集、数据处理、数据分析、数据展示和报告撰写。‌ 1.‌明确目的‌:这是数据分析的第一步,需要确定分析要解决的具体业务问题,并将业务问题转化为数学问题,以便于后续的数据处理和分析‌…

pyenv -- 一款macos下开源的多版本python环境安装管理工具 国内加速版安装 + 项目venv虚拟环境 pip加速 使用与总结

一个比较方便实用的python多版本环境安装管理工具, 阿里云加速版本 pyenv安装方法: 直接克隆本下面到你的本地目录,然后设置环境变量即可 git clone https://gitee.com/tekintian/pyenv.git ~/.pyenv 环境变量配置 在~/.bash_profile 或者 .zshrc 中增加环境变量 export …

docker在宿主机上最多可以创建多少个容器?

docker在宿主机上最多可以创建多少个容器? A. 1000 B. 和宿主机的cpu/memory 资源有关系 C. 不一定 选择C Docker 容器的数量受到宿主机的资源限制,包括CPU、内存和存储空间等。具体的容器数量取决于宿主机的硬件配置和资源使用情况。没有固定的数量限…

SPP/SPPF/Focal Module

一、在图像的分类任务重,卷积神经网络(CNN)一般含有5层: 输入层卷积层激活层池化层全连接层 全连接层通常要求输入为一维向量。在CNN中,卷积层和池化层的输出特征图会被展平(flatten)为一维…

《机器学习》—— OpenCV 对图片的各种操作

文章目录 1、安装OpenCV库2、读取、显示、查看图片3、对图片进行切割4、改变图像的大小5、图片打码6、图片组合7、图像运算8、图像加权运算 1、安装OpenCV库 使用pip是最简单、最快捷的安装方式 pip install opencv-python3.4.2还需要安装一个包含了其他一些图像处理算法函数的…

C——四种排序方法

这一篇文章我将要详细讲解四种排序方法 1.冒泡排序 冒泡排序是我们首先接触的排序方法&#xff0c;他通过两次循环完成。 /*冒泡排序*/&#xff08;升序&#xff09; void maopao(int *a,int n) {int i;for(i 0; i < n-1; i){for (int j 0; j < n - 1 - i; j){if (a[…

SprinBoot+Vue在线商城微信小程序的设计与实现

目录 1 项目介绍2 项目截图3 核心代码3.1 Controller3.2 Service3.3 Dao3.4 application.yml3.5 SpringbootApplication3.5 Vue3.6 uniapp代码 4 数据库表设计5 文档参考6 计算机毕设选题推荐7 源码获取 1 项目介绍 博主个人介绍&#xff1a;CSDN认证博客专家&#xff0c;CSDN平…

Linux CentOS 7.39 安装mysql8

1、新建mysql文件夹 数据比较大&#xff0c;所以我在服务器另外挂了一个盘装mysql&#xff0c;和默认安装一个道理&#xff0c;换路径即可 cd ../ //创建文件夹 mkdir mysql //进入mysql文件夹 cd mysql 2、下载mysql8.0安装包并解压、重命名 //下载安装包 wget https://dev…

vue3中使用supermap icilent3d for cesium

记录从头开始学习supermap icilent3d fro cesium 1.新建vue3项目 npm create vitelatest 添加这个&#xff0c;自动打开浏览器 2.使用supermap icilent3d for Cesium 复制这个Cesium&#xff0c;放到pulibc目录下面 然后分别引入css和js 然后就可以使用了&#xff0c;但是会…

Android强制设置所有应用显示方向,忽略应用本身的设置

在ROM定制系统开发过程中经常会遇到需要改变第三方应用显示方向的需求&#xff0c;比如抖音这种手机APP都是强制竖屏的&#xff0c;不会跟随屏幕旋转。但在一些平板方案开发中需要能横屏显示&#xff0c;或者需要跟随屏幕旋转方向动态切换横竖屏显示。这时就需要在系统层面去处…

萌新6:16进制世界(dp)

题目描述 这是一个16进制的世界&#xff0c;比如522的16进制是20A。 在5月22日那天&#xff0c;有人送给Bob一些月饼&#xff0c;每个月饼有饱食度和幸福度两个属性。 现在Bob有nnn个月饼&#xff0c;对于每个月饼iii&#xff0c;饱食度为viv_ivi​&#xff0c;幸福度为wiw_iw…

未来城市生活:科技与人文的交响

随着技术的发展&#xff0c;未来的城市生活正在以前所未有的速度演变。从智能家居到绿色能源解决方案&#xff0c;再到增强现实&#xff08;AR&#xff09;技术的应用&#xff0c;每一个方面都在重新定义我们对日常生活的认知。本文将探讨这些变化&#xff0c;并展望一个更加智…