api接口更新钉钉文档

news/2025/2/22 15:45:23/
class OperateKnowledgeBaseExcel():robot_code = ''    # agent_id = ''      #app_key = ''       #群机器人app_secret = ''    #群机器人def __init__(self,union_id, workbook_id, worksheet_id=''):self.union_id = union_idself.workbook_id = workbook_id  # 获取方式:... > 文档信息 > 表格IDself.worksheet_id =  worksheet_id # 获取方式:self.get_workbook_sheet_names() 拿到所有sheet名称和idif not self.union_id:raise Exception('请先设置union_id')def get_access_token(self):""" 获取token: https://open.dingtalk.com/document/orgapp/obtain-orgapp-token """headers = {'Content-Type': "application/x-www-form-urlencoded"}url = f"https://oapi.dingtalk.com/gettoken/?appkey={self.app_key}&appsecret={self.app_secret}"resp = requests.get(url, headers=headers)# print(resp.json()['access_token'])return resp.json()['access_token']self.access_token = self.get_access_token()def update(self, range_address, values):"""更新工作表指定区域的数据开发者文档:https://open.dingtalk.com/document/orgapp/get-cell-properties:param range_address: 更新区域,如:A2:B3:param values: 更新的数据,如:[['张三', 18], ['李四', 19]]"""url = f'https://oapi.dingtalk.com/v1.0/doc/workbooks/{self.workbook_id}/sheets/{self.worksheet_id}/ranges/{range_address}?operatorId={self.union_id}'headers = {'Content-Type': "application/json",'Host': 'api.dingtalk.com','x-acs-dingtalk-access-token': self.access_token}data = {"values": values}resp = requests.put(url, data=json.dumps(data), headers=headers)print("更新工作表区域:", resp.json())import pandas as pd
from robot.operate_knowledgebase import OperateKnowledgeBaseExcel
import json# 读取Excel文件
excel_file = r'D:\1.xlsx'
df = pd.read_excel(excel_file)workbook_id = ''   #钉钉文档表信息
union_id = ''      #用户id# 将数据转换为列表形式
values = df.values.tolist()
values = [[str(item) for item in row] for row in values]# 构造字典对象
data = values# 将字典对象转换为JSON字符串
json_data = json.dumps(data, ensure_ascii=False)worksheet_id = OperateKnowledgeBaseExcel(union_id, workbook_id).get_workbook_sheet_names()['value'][0]['id']print(json_data)
range_address = 'A2:L191'    #表的左上第一个,和右下最后一个位置
OperateKnowledgeBaseExcel(union_id, workbook_id, worksheet_id).update(range_address, json_data)

首先,在__init__方法中,需要传入union_idworkbook_id参数。其中,union_id是用户的唯一标识,workbook_id是钉钉文档表格的ID。如果没有设置union_id,将会抛出异常。

然后,get_access_token方法用于获取访问令牌。该方法发送请求到钉钉API,通过提供的app_keyapp_secret获取访问令牌,并返回响应中的access_token字段。

接下来,update方法用于更新工作表中指定区域的数据。它需要传入range_addressvalues参数,其中range_address表示要更新的区域,values是要更新的数据。该方法会构造请求URL,并发送PUT请求到钉钉API,将数据以JSON格式进行更新。

在你的代码示例中,首先读取了一个Excel文件1.xlsx,然后使用pd.read_excel方法将文件内容转换为DataFrame对象df

接着,将DataFrame对象中的数据转换为列表形式,并将每个元素转换为字符串类型。

然后,将数据列表转换为字典对象,并使用json.dumps方法将字典对象转换为JSON字符串。

之后,通过调用OperateKnowledgeBaseExcel类的实例化对象的get_workbook_sheet_names方法获取工作表的名称和ID,将第一个工作表的ID赋值给worksheet_id变量。

最后,调用OperateKnowledgeBaseExcel类的实例化对象的update方法,传入要更新的区域范围range_address和JSON数据json_data来更新工作表中的数据。


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

相关文章

【Java数据结构重点知识】第一节:认识数据结构与算法、集合框架

一:数据结构与算法 1.数据结构 数据结构是计算机存储、组织数据的方式,指相互之间存在一种或多种特定关系的数据元素的集合 2.算法 算法就是定义良好的计算过程。他取一个或一组的值为输入,并产生一个或一组作为输出。简单来说就是一系列的…

微信小程序拍照页面自定义demo

api文档 <template><div><imagemode"widthFix"style"width: 100%; height: 300px":src"imageSrc"v-if"imageSrc"></image><camerav-else:device-position"devicePosition":flash"flash&qu…

数据结构:算法(特性,时间复杂度,空间复杂度)

目录 1.算法的概念2.算法的特性1.有穷性2.确定性3.可行性4.输入5.输出 3.好算法的特质1.正确性2.可读性3.健壮性4.高效率与低存储需求 4.算法的时间复杂度1.事后统计的问题2.复杂度表示的计算1.加法规则2.乘法规则3.常见函数数量级比较 5.算法的空间复杂度1.程序的内存需求2.例…

vue项目引入elementui样式组件05

vue前端开发&#xff0c;关于样式部分&#xff0c;不需要自己去写&#xff0c;可以引用现有的一些组件&#xff0c;比如elemtnui&#xff0c;可官网查看 1、下载对应的包到vue项目中 通过npm进行安装 npm i element-ui -S2、引入到项目中&#xff0c;官网也提供了例子 3、运…

阿里云的OSS云存储的基本使用

阿里云官网&#xff1a;阿里云-计算&#xff0c;为了无法计算的价值 通过阿里云官网&#xff0c;登录进入用户的界面&#xff0c;在搜索框中输入OSS&#xff0c;然后进入阿里云的对象存储OSS的控制台。&#xff08;未开通的开通即可&#xff09; 创建 Bucket 点击【Bucket 列…

如何将word格式的文档转换成markdown格式的文档

如何将word格式的文档转换成markdown格式的文档 前言 A. 介绍Markdown和Word格式文档 什么是Markdown&#xff1f; Markdown是一种轻量级标记语言&#xff0c;旨在简化文本格式化和排版的过程。它以纯文本形式编写&#xff0c;通过使用简单的标记语法&#xff0c;使文档更具…

案例分析真题-系统建模

案例分析真题-系统建模 2009年真题 【问题1】 【问题2】 【问题3】 2012年真题 【问题1】 【问题2】 【问题3】 2014年真题 【问题1】 【问题2】 骚戴理解&#xff1a;这个题目以前经常考&#xff0c;不知道今年会不会考&#xff0c;判断的话就是看加工有没有缺少输入和输出&a…

网络安全(黑客)—小白自学路线

1.网络安全是什么 网络安全可以基于攻击和防御视角来分类&#xff0c;我们经常听到的 “红队”、“渗透测试” 等就是研究攻击技术&#xff0c;而“蓝队”、“安全运营”、“安全运维”则研究防御技术。 2.网络安全市场 一、是市场需求量高&#xff1b; 二、则是发展相对成熟…