当前位置: 首页 > article >正文

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

目录

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"]

相关文章:

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

目录 1.1 创建飞书开放平台应用 1.2 创建飞书多维表格 1.3 创建扣子平台插件 1.1 创建飞书开放平台应用 1.1.1 打开地址:飞书开放平台,点击创建应用 注:商店应用需要申请ISV资质,填写企业主体信息,个人的话&#x…...

C++-Mongoose(2)-https-server-openssl

OpenSSL生成HTTPS自签名证书 - 简书 1.Openssl windowsubuntu下载http://www.openssl.vip/download1.VS2019编译OpenSSL 2.VS2019编译第一个OpenSSL项目 1.ubuntu编译OpenSSL 3.0 2.编写第一个OpenSSL 1.windows下编译OpenSSL 安装vs2019 perl nasm安装activePerl…...

【GDB】调试程序的基本命令和用法(Qt程序为例)

1. 引言 GDB(GNU Debugger)是一个强大的命令行调试工具,它可以帮助开发者在程序运行时查找和修复错误。当调试Qt程序时,GDB同样适用,并且能够帮助开发者定位诸如数组越界挂死等复杂问题。 2. 基本命令 2.1 启动GDB …...

力扣DAY46-50 | 热100 | 二叉树:展开为链表、pre+inorder构建、路径总和、最近公共祖先、最大路径和

前言 中等 、困难 √,越来越有手感了,二叉树done! 二叉树展开为链表 我的题解 前序遍历树,当遇到左子树为空时,栈里pop节点,取右子树接到左子树位置,同时断开该右子树与父节点的连接&#x…...

服务器DNS失效

服务器异常 xx.t.RequestException: java.net.UnknownHostException: test.ac.xxxx.cn现象分析 本地测试正常,说明域名本身无问题。服务器 DNS 解析异常,导致 UnknownHostException。**服务器可正常解析 ****baidu.com**,说明网络正常&#…...

用excel做九乘九乘法表

公式: IF($A2>B 1 , 1, 1,A2 & “" & B$1 & “” & $A2B$1,”")...

企业数据安全如何保障?深度解析AIGC系统源码本地化部署

—从数据加密到权限管控,构建企业级AI安全防线 企业AIGC面临的5大数据安全风险 1. 数据出境违规 典型场景: 使用ChatGPT处理客户信息 → 数据经美国服务器中转 → 违反《个人信息保护法》第38条某金融公司因通过Midjourney生成宣传图,导致产…...

《妖风》-来自DeepSeek

《妖风》 周明揉了揉酸胀的眼睛,电脑屏幕上的Excel表格已经模糊成一片绿色的小格子。窗外,三月的阳光懒洋洋地洒进来,带着春天特有的那种让人昏昏欲睡的温暖。办公室里中央空调的嗡嗡声像是一首催眠曲,他的眼皮越来越重。 "…...

鬼泣:蓄力攻击

文章目录 蓄力攻击:有两个动作,蓄力时触发蓄力动作,攻击时触发攻击动作1.蓄力动作2.攻击动作 浮空上挑1.蓄力对齐位置 2.攻击 下劈斩1.蓄力对齐位置 2.攻击 beiwuf debug事件分发器发送:调用发送器即可发送消息接收:绑…...

企业指标设计方法指南

该文档聚焦企业指标设计方法,适用于企业中负责战略规划、业务运营、数据分析、指标管理等相关工作的人员,如企业高管、部门经理、数据分析师等。 主要内容围绕指标设计展开:首先指出指标设计面临的困境,包括权责不清、口径不统一、缺乏标准规范、报表体系混乱、指标…...

CSS学习02 动态列数表格开发,解决多组数据布局与边框重合问题

概要 在前端开发中,表格常用于展示结构化数据。当数据组的字段数量不统一时(如有的行包含 3 组数据,有的行包含 2 组或 1 组),传统固定列数的表格会出现结构错位、边框重合等问题。本文通过 HTML/CSS 规范方法&#x…...

加载js/mjs模块时服务器返回的 MIME 类型不对导致模块被拒绝执行

浏览器报错 Failed to load module script: The server responded with a non-JavaScript MIME type of "text/html". Strict MIME type checking is enforced for module scripts per HTML spec.Understand this errorAI 核心问题 浏览器加载模块脚本(如…...

大唐杯省赛安排来了!还有7天,该如何准备?

(一)赛道一:工程实践赛 1、理论赛阶段由参赛队伍使用两台电脑分别登录学唐平台作答,仿真实践赛阶段为参赛队伍共用一台电脑,以竞赛小组方式共同作答(按照报名顺序,用第1选手账号登录仿真平台)。最终统计理…...

iframe学习与应用场景指南

一、iframe核心原理与学习路径 1. 嵌套网站的本质原理 技术特性: • 浏览器为每个iframe创建独立的window对象和DOM环境 • 资源独立加载:子页面拥有自己的CSS/JS/Cookie作用域 • 跨域限制:同源策略下无法直接访问DOM(需CORS或…...

WebGL数学手记:矩阵基础

一、矩阵的定义 矩阵,数学术语。在数学中,矩阵(Matrix)是一个按照长方阵列排列的复数或实数集合。 1.英文发音(Matrix) Matrix的发音类似于中文的[美吹克斯],知道它的发音。方便后期看教程时…...

IO流——字符输入输出流:FileReader FileWriter

一、文件字符输入流:FileReader 作用:以内存为基准,可以把文件中的数据以字符的形式读入到内存中去 public class Test5 {public static void main(String[] args) {try (Reader fr new FileReader("E:\\IDEA\\JavaCodeAll\\file-io-t…...

Graphpad Prism for Mac医学绘图

Graphpad Prism for Mac医学绘图 一、介绍 GraphPad Prism for Mac是一款功能强大、易于使用的科学和统计分析软件,适用于各种类型的数据处理和可视化需求。无论您是进行基础研究、临床试验还是学术写作,GraphPad Prism for Mac都能为您短时间内做出最…...

使用人工智能大模型腾讯元宝,如何免费快速做高质量的新闻稿?

今天我们学习使用人工智能大模型腾讯元宝,如何免费快速做高质量的新闻稿? 手把手学习视频地址:https://edu.csdn.net/learn/40402/666431 第一步在腾讯元宝对话框中输入如何协助老师做新闻稿,通过提问,我们了解了老师…...

破解root密码

一、背景: 必须是服务器的管理者,涉及重启服务器 二、破解过程: 1)重启系统,进入 救援模式 开机过程中,按e进入救援模式 在linux开头的该行,将此行的ro修改为rw 然后空格输入 rd.break 按 ctrl x 启动,…...

嵌入式---烧录器

一、核心定义与本质功能 烧录器(Programmer)是一种将用户编写的程序代码(如.hex/.bin文件)写入单片机内部存储器(Flash/EEPROM/ROM)的专用工具,核心功能包括: 程序烧写&#xff1a…...

机器学习 | 强化学习基本原理 | MDP | TD | PG | TRPO

文章目录 📚什么是强化学习🐇监督学习 vs 强化学习🐇马尔科夫决策过程(MDP)📚基本算法(value-based & policy-based)🐇时序差分算法(TD)🐇SARSA和Q-learning🐇策略梯度算法(PG)🐇REINFORCE和Actor-Critic🐇信任区域策略优化算法(TRPO)⭐️参考…...

Spring中使用Kafka的详细配置,以及如何集成 KRaft 模式的 Kafka

在 Spring 中使用 Apache Kafka 的配置主要涉及 Spring Boot Starter for Kafka,而开启 ‌KRaft 模式‌(Kafka 的元数据管理新模式,替代 ZooKeeper)需要特定的 Kafka Broker 配置。以下是详细步骤: 一、Spring 中集成 …...

llinux上的pip国内镜像全局配置

1、创建全局 pip 配置文件&#xff08;推荐&#xff09; sudo tee /etc/pip.conf <<EOF [global] index-url https://pypi.tuna.tsinghua.edu.cn/simple trusted-host pypi.tuna.tsinghua.edu.cn EOF2、验证配置 任意用户运行以下命令应显示配置的镜像&#xff1a; …...

ASEG的鉴定

等位基因特异性表达(Allele-Specific Expression, ASE)基因的鉴定是研究杂种优势和基因表达调控的重要手段。以下是鉴定ASE基因的详细流程和方法: ### **1. 实验设计与样本准备** - **选择材料**:选择杂交种及其亲本作为研究材料。例如,玉米中的B73和Mo17及其杂交组合B73…...

swift菜鸟教程14(闭包)

一个朴实无华的目录 今日学习内容&#xff1a;1.Swift 闭包1.1闭包定义1.2闭包实例1.3闭包表达式1.3.1sorted 方法&#xff1a;据您提供的用于排序的闭包函数将已知类型数组中的值进行排序。1.3.2参数名称缩写&#xff1a;直接通过$0,$1,$2来顺序调用闭包的参数。1.3.3运算符函…...

新手宝塔部署thinkphp一步到位

目录 一、下载对应配置 二、加载数据库 三、添加FTP​ 四、上传项目到宝塔​ 五、添加站点​ 六、配置伪静态 七、其他配置 开启监控 八、常见错误 一、打开宝塔页面&#xff0c;下载对应配置。 二、加载数据库 从本地导入数据库文件 三、添加FTP 四、上传项目到宝塔…...

Java常用工具算法-7--秘钥托管云服务2(阿里云 KMS)

阿里云的KMS&#xff08;Key Management Service&#xff09;也是一种托管式密钥管理服务&#xff0c;帮助用户安全地创建、控制和使用密钥&#xff0c;保护敏感数据。通过使用KSM&#xff0c;您可以专注于构建和优化应用程序&#xff0c;而不必担心密钥管理的复杂性。 1、主要…...

基于STM32 的实时FFT处理(Matlab+MDK5)

目录 一、 任务介绍二、基本原理三、软件仿真3.1 软件仿真基本原理3.2 软件仿真序列的软件模拟 四、模拟测试五、 附加题六、 源码 一、 任务介绍 1、在硬件平台上实现 FFT 算法&#xff1b; 2、模拟数据&#xff0c;通过 FFT 算法进行谱分析&#xff1b; 3、测定 PWM 输出方波…...

RVOS-3.实现内存管理

3.内存管理 3.1 实验目的 对内存进一步的管理&#xff0c;实现动态的分配和释放。 实现 Page 级别的内存分配和释放。 在 page 分配的基础上实现更细颗粒度的&#xff0c;精确到字节为单位的内存管理。 &#xff08;练习8.1&#xff09; void *malloc(size_t size); void fr…...

MySQL 约束(入门版)

目录 一、约束的基本概念 二、约束演示 三、外键约束 &#xff08;一&#xff09;介绍 &#xff08;二&#xff09;外键约束语法 &#xff08;三&#xff09;删除/更新行为 一、约束的基本概念 1、概念&#xff1a;约束是作用于表中字段上的规则&#xff0c;用于限制存储…...