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()
相关推荐
zb200641201 小时前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
一勺菠萝丶2 小时前
Flowable + Spring 集成踩坑:流程结束监听器查询历史任务为空 & 获取不到审批意见
java·数据库·spring
jwn9992 小时前
Spring Boot 整合 Keycloak
java·spring boot·后端
宁波阿成2 小时前
OpenClaw 在 Ubuntu 22.04.5 LTS 上的安装与问题处理记录
java·linux·ubuntu·openclaw·龙虾
mldlds2 小时前
SpringBoot详解
java·spring boot·后端
kang_jin2 小时前
Spring Boot 自动配置
java·spring boot·后端
sg_knight2 小时前
如何用 Claude Code 做大型项目重构与架构优化
java·重构·架构·llm·claude·code·claude-code
码不停蹄Zzz2 小时前
C语言——神奇的static
java·c语言·开发语言
带娃的IT创业者2 小时前
WeClaw 离线消息队列实战:异步任务队列如何保证在服务器宕机时不丢失任何一条 AI 回复?
运维·服务器·人工智能·python·websocket·fastapi·实时通信