关注

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()


转载自CSDN-专业IT技术社区

原文链接:https://blog.csdn.net/gf1321111/article/details/159093118

评论

赞0

评论列表

微信小程序
QQ小程序

关于作者

点赞数:0
关注数:0
粉丝:0
文章:0
关注标签:0
加入于:--