通过扣子平台将数据写入飞书多维表格

目录

1.1 创建飞书开放平台应用

1.2 创建飞书多维表格

1.3 创建扣子平台插件


1.1 创建飞书开放平台应用 

   1.1.1 打开地址:飞书开放平台,点击创建应用

注:商店应用需要申请ISV资质,填写企业主体信息,个人的话,选择【创建企业自建应用】
商店应用:

企业自建应用 

 

点击【创建】按钮创建成功后如下:

 配置应用操作多维表格的权限

 配置完成后需要发布应用才会生效,进入【版本管理与发布 _ 创建版本】

 

 发布完成后,添加多维表格,并且添加应用权限

1.2 创建飞书多维表格

登录飞书 _> 新建多维表格:https://fcnm73x3rsfr.feishu.cn/drive/home

将应用添加为多维表格协作者

 

 

通过应用API向多维表格插入一条记录,进入飞书开放平台-> 权限管理 -> 进入API调试台。

点击击【相关API事件 _ API新增多条记录】跳转到API开发文档,可以打开【API调试台】进行接口调试

 

获取app_token(即base_id) 和 table_id 

 

 调用成功

 通过飞书开放平台应用将数据写入多维表格成功

企业自建应用开发流程文档:
https://open.feishu.cn/document/home/introduction-to-custom-app-development/self-built-application-development-process

1.3 创建扣子平台插件

1.3.1 登录扣子平台:扣子

创建插件

 

 创建工具(插件包含一个或多个工具)

 添加输入参数

 

 输入参数添加成功后,此处可以通过输入参数首字母,就是自动弹出输入参数的提示下拉框供选择

 代码写完后,点此处运行

 

 

 此处需要替换为自己的飞书应用id,才能获取到正确的token

 飞书开放平台的app_id 和 app_secret在这里获取

 返回400或403报错参考飞书开放平台API:新增多条记录 - 服务端 API - 飞书开放平台

 

 上面标红框的部分需要替换为自己飞书多维表格的base_id和table_id,前面创建飞书多维表格流程中有标识base_id(即app_token)和table_id 的地方

以上报错403是飞书开放平台的应用没有飞书多维表格的权限,同时检查app_id和app_secret,如果这两个值不正确,也会报403

1. 需要在多维表格中将飞书应用添加为协作者

 

 

 2. 需要开启飞书多维表格高级权限

 

 前面添加的飞书应用协作者会在这里显示

 再次点击运行按钮,显示成功,同时飞书多维表格会新增相应数据

 

 扣子平台插件工具输入参数如下:

{"c_index":1,

"c_data" : "\n{\n \"人物列表\": [\n {\n \"姓名\": \"陈德修\",\n \"年龄\": \"50岁左右\",\n \"性别\": \"男\",\n \"身高\": \"\",\n \"体重\": \"\",\n \"五官特征\": \"戴着厚厚的金丝眼镜\",\n \"身形描述\": \"地中海发型\",\n \"性格标签\": \"德高望重;医者仁心\",\n \"穿着打扮\": \"医生职业装\",\n \"神态动作\": \"无奈地叹息;递诊断书—动作沉稳\"\n },\n {\n \"姓名\": \"庄子昂\",\n \"年龄\": \"18岁\",\n \"性别\": \"男\",\n \"身高\": \"\",\n \"体重\": \"\",\n \"五官特征\": \"斯文气质;眼角有泪痕—动态\",\n \"身形描述\": \"青葱少年\",\n \"性格标签\": \"循规蹈矩;情绪压抑;故作轻松\",\n \"穿着打扮\": \"艳俗花衬衫—五彩斑斓;沾消毒水味的衣服\",\n \"神态动作\": \"浑浑噩噩走路—撞倒共享单车;手颤抖握诊断书;挤苦涩笑容\"\n },\n {\n \"姓名\": \"林慕诗\",\n \"年龄\": \"约18岁\",\n \"性别\": \"女\",\n \"身高\": \"\",\n \"体重\": \"\",\n \"五官特征\": \"丹凤眼;牛奶般白皙肌肤\",\n \"身形描述\": \"颇具规模的胸脯—动态起伏\",\n \"性格标签\": \"傲娇;外冷内热\",\n \"穿着打扮\": \"\",\n \"神态动作\": \"轻抿奶茶—动作优雅;瞪丹凤眼质问\"\n },\n {\n \"姓名\": \"李黄轩\",\n \"年龄\": \"约18岁\",\n \"性别\": \"男\",\n \"身高\": \"\",\n \"体重\": \"\",\n \"五官特征\": \"\",\n \"身形描述\": \"瘦高个\",\n \"性格标签\": \"活泼;爱调侃\",\n \"穿着打扮\": \"\",\n \"神态动作\": \"大笑着调侃;揽肩膀—动作亲昵\"\n }\n ]\n}\n"

}

 扣子平台插件工具代码如下:

import json
import requests
from runtime import Args
from typings.write_data_to_feishu_excel.write_data_to_feishu_excel import Input, Output"""
Each file needs to export a function named `handler`. This function is the entrance to the Tool.Parameters:
args: parameters of the entry function.
args.input - input parameters, you can get test input value by args.input.xxx.
args.logger - logger instance used to print logs, injected by runtime.Remember to fill in input/output in Metadata, it helps LLM to recognize and use tool.Return:
The return data of the function, which should match the declared output parameters.
"""class Output:def __init__(self, code: int, message: str, data: str):self.code = codeself.message = messageself.data = data# 此处handler命名不能更改
def handler(args: Args[Input])->Output:args.logger.info(f"输入参数{args.input}")# 检查 args.input 是否为 Noneif args.input is None:return Output(code=400, message="args.input 为 None,请检查传入的参", data="")# 替换为实际值token = getFeishuToken(args)args.logger.info(f"当前token值:{token}")base_id = "飞书多维表格的base_id"table_id = "飞书多维表格的table_id"characters = args.input.c_dataif not characters:return Output(code=500, message="缺少必要参数: c_data",data="")json_data = getCharactersData(args, characters)args.logger.info(f"写入数据:{json_data}")# 构造请求体data = {"records": json_data# "records":  [#     {#         "fields": json_obj#     }# ]}# 单行数据写入API地址#https://open.feishu.cn/open-apis/bitable/v1/apps/飞书多维表格的base_id/tables/飞书多维表格的table_id/records# 多行数据写入,调用写入 APIurl = f"https://open.feishu.cn/open-apis/bitable/v1/apps/{base_id}/tables/{table_id}/records/batch_create"args.logger.info(f"飞书多维表格写入地址{url}")headers = {"Authorization": f"Bearer {token}","Content-Type": "application/json",#'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/119.0.0.0 Safari/537.36',}try:response = requests.post(url, json=data , headers=headers)response.raise_for_status()args.logger.info(f"Data written result:{response.json()}")except requests.exceptions.RequestException as e:args.logger.info(f"Request error:{e}")return Output(code=500, message="失败", data="API请求异常")except ValueError as e:args.logger.info(f"JSON parsing error:{e}")return Output(code=500, message="失败", data="json数据转换异常")except Exception as e:args.logger.info(f"An unknown error occurred:{e}")return Output(code=500, message="失败", data=f"An unknown error occurred:{e}")return Output(code=200, message="成功", data=str(data))# 解析输入的内容(示例数据是json格式)
def getCharactersData(args, input_data):args.logger.info(f"当前输入参数:{input_data}")json_data = [] # 如果输入是字符串则解析,否则直接使用if isinstance(input_data, str):# 清除输入内容中的json标识json_data = json.loads(input_data.replace("```","").replace("json",""))else:# 假设已经是解析好的对象json_data = input_data# 强制转换为列表(确保可迭代性)(示例)#if not isinstance(json_data, list):#    json_data = [json_data]# 自动获取JSON键作为列名(示例)#columns = list(flattened_data[0].keys())# 扁平化数据结构flattened_data = []for index, item in enumerate(json_data["人物列表"]):# 3.1 确保item是字典类型#if not isinstance(item, dict):# 非字典类型特殊处理#    item = {"raw_data": item}  # 需确保所有字段存在(防止KeyError),此处json的key名和飞书多维表格列名一致,故使用copy方法flat_item = item.copy()flat_item['章节'] = str(args.input.c_index)# 若json的key名和飞书多维表格列名不一致,此处进行转换name为飞书多维表格列名,姓名为json数据的key名# flat_item = {#     'name': item.get('姓名', ""),#     'age': item.get('年龄区间', ""),#     'features': item.get('五官特征', ""),#     'body': item.get('身形描述', ""),#     'temperament': item.get('性格标签', ""),#     'dress': item.get('穿着打扮', ""),#     'look': item.get('神态动作', ""),#     'sex': item.get('性别', ""),#     'height': item.get('身高', ""),#     'weight': item.get('体重', "")# }# 3.3 若输入的json数据存在嵌套,处理嵌套结构(示例)if 'appearance' in item:appearance = item.get('appearance', {})flat_item.update({'features': str(appearance.get('五官特征', '')),'body': str(appearance.get('身形描述', ''))})# 飞书开放平台API中行数据是放在fields对象中的,多行就是多个fields对象flattened_data.append({"fields": flat_item})return flattened_data# 获取访问令牌token
def getFeishuToken(args):token_url = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal"token_response = requests.post(token_url, json={"app_id": "飞书开放平台应用的app_id","app_secret": "飞书开放平台应用的app_secret"})#注意:令牌有效期为 2 小时,需定期刷新#响应token:{'code': 0, 'expire': 7200, 'msg': 'ok', 'tenant_access_token': 't-g104439u6OYLPGRXP656CNK27CSDYNNNUFTMKRFT'}res = token_response.json()args.logger.info(f"响应token{res}")return token_response.json()["tenant_access_token"]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/76012.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

MYSQL数据库语法补充

一,DQL基础查询 DQL(Data Query Language)数据查询语言,可以单表查询,也可以多表查询 语法: select 查询结果 from 表名 where 条件; 特点: 查询结果可以是:表中的字段…

Redis到底能不能做主数据库?

张三拍案而起:“Redis 是缓存数据库,怎么能当主数据库用?简直是天方夜谭!” 李四冷笑回应:“你没用过,凭什么说不行?我已经用 Redis 做主数据库好几年了,系统稳定得像铁板一块&…

flutter 项目结构目录以及pubspec.ymal等文件描述

在Flutter项目中,目录结构和pubspec.yaml文件是非常重要的组成部分,它们定义了项目的结构、依赖管理以及如何构建和运行项目。下面我将详细解释这些关键元素: 1. Flutter项目目录结构 Flutter项目的标准目录结构通常如下所示: …

CentOS 环境下 MySQL 数据库全部备份的操作指南

最近阿里云个人服务到期,因为是很久之前买的测试机器,配置较低,上面运行的有技术博客 和以往的测试项目,所以准备放弃掉。 需要备份下上面的表结构和数据、以及代码仓库。 下面是一个完整的 CentOS 环境下 MySQL 数据库全部备份…

ecplise 工具 没有Java EE Tools 选项

Java EE Tools 是将项目转换为web项目的重要的快捷键,如果进行web开发 那是不可或缺的 该工具是一个插件,可以作为插件安装到ecplise上 安装步骤如下: 找到help-->install new software 在弹出的页面中 work with中输入:Jun…

544 eff.c 1761 优化设计文档

1:性能分析 1.1性能对比 oneapi 与hygonGcc性能对比发现,544课题中的eff.c 1761循环处,oneapi 进行了循环向量化, gcc使用标量,循环源码前加 #pragma clang loop vectorize(disable) 找出oneapi在该循环处关闭和开启loop vect 的性能差距&a…

LeetCode.3396.使数组元素互不相同所需的最少操作次数

3396. 使数组元素互不相同所需的最少操作次数 给你一个整数数组 nums,你需要确保数组中的元素 互不相同 。为此,你可以执行以下操作任意次: 从数组的开头移除 3 个元素。如果数组中元素少于 3 个,则移除所有剩余元素。 注意&…

【已完结STM32】--自学江协科技笔记汇总

以下学习笔记代码均来自b站江协科技视频 笔记汇总完结 文章笔记对应江科大视频新建工程【2-2】新建工程江科大STM32-GPIO输出 点亮LED,LED闪烁,LED流水灯,蜂鸣器(学习笔记)_unit32-t rcc-apb2periph-CSDN博客 【3-1】…

QML Loader:加载组件与状态监控

目录 引言相关阅读工程结构示例一:从文件加载组件 (LoaderFile.qml)代码实现被加载的组件:MyComponent.qml代码解析运行效果 示例二:直接加载Component对象 (LoaderComponent.qml)代码实现代码解析运行效果 示例三:监控加载状态 (…

K8S核心技术点

Pod,Service和Deployment的关系 Pod:Kubernetes 中最小的部署单元,用于运行容器化应用。 Service:提供服务发现和负载均衡,为 Pod 提供稳定的网络端点,ClusterIP,NodePort,LoadBala…

Spring 核心注解深度解析:@Autowired、@Repository 与它们的协作关系

引言 在 Spring 框架中,​依赖注入(DI)​​ 是实现松耦合架构的核心机制。Autowired 和 Repository 作为两个高频使用的注解,分别承担着 ​依赖装配​ 和 ​数据访问层标识​ 的关键职责。本文将深入探讨它们的功能特性、协作模式…

[Linux]从零开始的ARM Linux交叉编译与.so文件链接教程

一、前言 最近在项目需要将C版本的opencv集成到原本的代码中从而进行一些简单的图像处理。但是在这其中遇到了一些问题,首先就是原本的opencv我们需要在x86的架构上进行编译然后将其集成到我们的项目中,这里我们到底应该将opencv编译为x86架构的还是编译…

svelte+vite+ts+melt-ui从0到1完整框架搭建

框架太“重”了:通常一个小型项目只由少数几个简单页面构成,如果使用 Vue 或者 React 这些框架来研发的话,有点“大材小用”了。构建的产物中包含了不少框架运行时代码(虚拟 DOM、响应式、状态管理等),这些代码对于小型项目而言是…

无法看到新安装的 JDK 17

在 Linux 系统中使用 update-alternatives --config java 无法看到新安装的 JDK 17,可能是由于 JDK 未正确注册到系统备选列表中。 一、原因分析 JDK 未注册到 update-alternatives update-alternatives 工具需要手动注册 JDK 路径后才能识别新版本。如果仅安装 JDK…

鼎讯信通 便携式雷达信号干扰模拟器:打造实战化电磁环境的新利器

在现代战争中,电磁环境的复杂性直接影响着雷达装备的性能和作战效果。面对敌方日益精进的电子战手段,如何提升雷达设备的抗干扰能力,确保其在实战环境中的稳定性和可靠性,已成为各国军队和科研机构的重要课题。 为此,…

【AI提示词】决策专家

提示说明 决策专家可以帮助你进行科学决策,尽可能避免错误,提升决策成功的概率。 提示词 # Role : 决策专家决策,是面对不容易判断优劣的几个选项,做出正确的选择。说白了,决策就是拿个主意。决策专家是基于科学决策…

力扣Hot100题,刷题

力扣HOT100 - 1. 两数之和 解题思路&#xff1a; 解法一&#xff1a;暴力 class Solution {public int[] twoSum(int[] nums, int target) {int n nums.length;for (int i 0; i < n; i)for (int j i 1; j < n; j) {if (target nums[i] nums[j])return new int[]…

uni-app ucharts自定义换行tooltips

实现效果&#xff1a; 第一步&#xff1a;在uni_modules文件夹下找到config-ucharts.js和u-charts.js文件 第二步&#xff1a;在config-ucharts.js文件中配置换行格式 // 换行格式"wrapTooltip":function(item, category, index, opts){return item.name&#xff1a;…

国标GB28181视频平台EasyCVR顺应智慧农业自动化趋势,打造大棚实时视频监控防线

一、方案背景 近年来&#xff0c;温室大棚种植技术凭借其显著的优势&#xff0c;在提升农作物产量和质量、丰富农产品供应方面发挥了重要的作用&#xff0c;极大改善了人们的生活水平&#xff0c;得到了广泛的推广和应用。大棚内的温度、湿度、光照度和二氧化碳浓度等环境因素…

InternVideo2.5:Empowering Video MLLMs with Long and Rich Context Modeling

一、TL&#xff1b;DR InternVideo2.5通过LRC建模来提升MLLM的性能。层次化token压缩和任务偏好优化&#xff08;mask时空 head&#xff09;整合到一个框架中&#xff0c;并通过自适应层次化token压缩来开发紧凑的时空表征MVBench/Perception Test/EgoSchema/MLVU数据benchmar…