python_查询并删除飞书多维表格中的记录

python_查询并删除飞书多维表格中的记录

python 复制代码
import requests
import json

# 飞书应用配置
APP_ID = "XXX"
APP_SECRET = "XXX"

# 表格配置
FEISHU_CONFIG = {
    "售前": {
        "app_token": "售前的app_token",
        "table_id": "售前的table_id",
        "view_id": "售前的view_id"
    },
    "售后": {
        "app_token": "XXX",
        "table_id": "XXX",
        "view_id": "XXX"
    }
}

startTriggerDict={"data":{"service_stage":"售后","rpa_coach":"火山","support_record_id_in_aw":"3"}}

APP_TOKEN = FEISHU_CONFIG[startTriggerDict["data"]["service_stage"]]["app_token"]
TABLE_ID = FEISHU_CONFIG[startTriggerDict["data"]["service_stage"]]["table_id"]
VIEW_ID = FEISHU_CONFIG[startTriggerDict["data"]["service_stage"]]["view_id"]

def get_tenant_access_token():
    """获取 tenant_access_token"""
    url = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal"
    headers = {
        "Content-Type": "application/json; charset=utf-8"
    }
    data = {
        "app_id": APP_ID,
        "app_secret": APP_SECRET
    }
    
    response = requests.post(url, headers=headers, json=data)
    result = response.json()
    
    if result.get("code") == 0:
        return result.get("tenant_access_token")
    else:
        raise Exception(f"获取token失败: {result.get('msg')}")

def query_support_info_in_feishu_by_aw_record_id(token,support_record_id_in_aw):
    """查询飞书多维表格里面AW中的支持记录对应ID所在行信息"""
    url = f"https://open.feishu.cn/open-apis/bitable/v1/apps/{APP_TOKEN}/tables/{TABLE_ID}/records/search"
    headers = {
        "Authorization": f"Bearer {token}",
        "Content-Type": "application/json; charset=utf-8"
    }
    data = {
        "view_id":VIEW_ID,
        "field_names": ["AW中的ID"],
        "filter": {
            "conjunction": "and",
            "conditions": [
                {
                    "field_name": "AW中的ID",
                    "operator": "is",
                    "value": [support_record_id_in_aw]
                }
            ]
        }
    }
    
    response = requests.post(url, headers=headers, json=data)
    result = response.json()
    
    if result.get("code") == 0:
        items = result.get("data", {}).get("items", [])
        if len(items) > 0:
            feishu_record_id=items[0]["record_id"]
            return feishu_record_id
        else:
            raise Exception("未找到对应的支持记录行信息")
    else:
        raise Exception(f"查询记录失败: {result.get('msg')}")

def delete_support_info_by_feishu_record_id(token, feishu_record_id):
    """删除飞书多维表格中的支持记录行信息"""
    url = f"https://open.feishu.cn/open-apis/bitable/v1/apps/{APP_TOKEN}/tables/{TABLE_ID}/records/{feishu_record_id}"
    headers = {
        "Authorization": f"Bearer {token}",
        "Content-Type": "application/json; charset=utf-8"
    }
    response = requests.delete(url, headers=headers)
    result = response.json()

    if result.get("code") == 0:
        return f"飞书多维表格中'AW中的ID'为:{startTriggerDict['data']['support_record_id_in_aw']}的行信息已删除"
    else:
        raise Exception(f"删除记录失败: {result.get('msg')}")

def main():
    try:
        print("开始获取 tenant_access_token...")
        token = get_tenant_access_token()
        print(f"成功获取 token: {token[:20]}...")
        
        print(f"\n开始")
        feishu_record_id = query_support_info_in_feishu_by_aw_record_id(token,startTriggerDict['data']["support_record_id_in_aw"])
        print(f"查询结果: {feishu_record_id}")

        delete_result = delete_support_info_by_feishu_record_id(token, feishu_record_id)
        print(f"删除结果: {delete_result}")

    except Exception as e:
        print(f"\n❌ 错误: {e}")
        import traceback
        traceback.print_exc()

if __name__ == "__main__":
    main()
相关推荐
李昊哲小课13 小时前
Python办公自动化教程 - 第5章 图表创建 - 让数据可视化
python·信息可视化·数据分析·数据可视化·openpyxl
chushiyunen13 小时前
python pygame实现贪食蛇
开发语言·python·pygame
Dream of maid13 小时前
Python-基础2(流程控制)
python
身如柳絮随风扬13 小时前
Lambda、方法引用与Stream流完全指南
java·开发语言
yaoyouzhong14 小时前
基于SpringBoot和PostGIS的云南与缅甸的千里边境线实战
java·spring boot·spring
姗姗的鱼尾喵14 小时前
Spring/SpringBoot 面试高频(含IOC/AOP/事务)
java·spring boot·面试
Mr_Xuhhh14 小时前
从理论到实践:深入理解算法的时间与空间复杂度
java·开发语言·算法
望眼欲穿的程序猿15 小时前
Vscode Clangd 无法索引 C++17 或者以上标准
java·c++·vscode
Lenyiin15 小时前
《Python 修炼全景指南:一》从环境搭建到第一个程序
开发语言·python
带刺的坐椅15 小时前
Spring-AI 与 Solon-AI 深度对比分析报告
java·spring·ai·llm·solon·spring-ai·solon-ai