【python_使用指定应用发送飞书卡片】

【python_使用指定应用发送飞书卡片】

python 复制代码
import requests
import json

def get_tenant_access_token():
    """
    步骤一:获取 tenant_access_token
    这是调用飞书服务端 API 的全局唯一凭证
    """
    url = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal"
    headers = {
        "Content-Type": "application/json"
    }
    payload = {
        "app_id": APP_ID,
        "app_secret": APP_SECRET
    }
    
    response = requests.post(url, headers=headers, data=json.dumps(payload))
    result = response.json()
    
    if result.get("code") == 0:
        return result["tenant_access_token"]
    else:
        raise Exception(f"获取 Token 失败: {result}")

def send_card_message(receive_open_id, card_template_id,submit_time, rpa_coach_open_id, record_id_in_aw, enterprise_name, start_and_end_time, support_content_needed, customer_success_open_id,multiTerminalUrl):
    """
    步骤二:发送卡片消息
    :param receive_open_id: 接收者的 Open ID
    :param card_template_id: 在卡片搭建平台创建的卡片模板 ID
    """
    # 获取凭证
    token = get_tenant_access_token()
    
    # 构建请求 URL
    url = "https://open.feishu.cn/open-apis/im/v1/messages"
    
    # 查询参数:指定 ID 类型为 open_id
    params = {
        "receive_id_type": "open_id"
    }
    
    # 请求头
    headers = {
        "Authorization": f"Bearer {token}",
        "Content-Type": "application/json"
    }
    
    # 请求体:发送模板卡片
    data = {
        "receive_id": receive_open_id,
        "msg_type": "interactive", # 卡片消息类型固定为 interactive
        "content": json.dumps({
            "type": "template",
            "data": {
                "template_id": card_template_id,
                # 如果你的卡片绑定了变量,需要在这里传入 template_variable 字段
                "template_variable": {
                    "submit_time": submit_time,
                    "rpa_coach_open_id": rpa_coach_open_id,
                    "customer_success_open_id": customer_success_open_id,
                    "record_id_in_aw": record_id_in_aw,
                    "enterprise_name": enterprise_name,
                    "start_and_end_time": start_and_end_time,
                    "support_content_needed": support_content_needed,
                    "multiTerminalUrl": multiTerminalUrl
                }
            }
        })
    }
    
    # 发送 POST 请求
    response = requests.post(url, params=params, headers=headers, data=json.dumps(data))
    result = response.json()
    
    if result.get("code") == 0:
        print("🎉 卡片发送成功!")
        print("消息 ID:", result.get("data", {}).get("message_id"))
    else:
        print("❌ 发送失败:", result)

# --- 执行代码 ---
if __name__ == "__main__":
    # 1. 配置你的应用凭证 (请替换为你的实际 ID 和 Secret)
    APP_ID = "XXX"
    APP_SECRET = "XXX"

    # 替换为实际的接收者 Open ID 和卡片 ID
    RECEIVER_OPEN_ID = "XXX"
    CARD_ID = "XXX" 

    #卡片里面的参数
    submit_time = "2024-06-01 09:00:00"
    rpa_coach_open_id= "XXX"  # 替换为实际的 RPA 教练 Open ID
    customer_success_open_id="XXX"  # 替换为实际的客户成功经理 Open ID
    record_id_in_aw="1234567890"
    enterprise_name="飞书科技有限公司"
    start_and_end_time="2024-06-01 10:00:00 ~ 2024-06-01 11:00:00"
    support_content_needed="需要支持的内容示例"
    file_url="https://winrobot-ai-power.yingdao.com/ca778869-49c2-4ead-90f7-1c52b731f32e"
    multiTerminalUrl={
        "pc_url": file_url,
        "android_url": file_url,
        "ios_url": file_url,
        "url": file_url
        }
    
    send_card_message(RECEIVER_OPEN_ID, CARD_ID,submit_time,rpa_coach_open_id, record_id_in_aw, enterprise_name, start_and_end_time, support_content_needed, customer_success_open_id,multiTerminalUrl)
相关推荐
金銀銅鐵11 分钟前
[Python] 扩展欧几里得算法
python·数学·算法
Duckdblab25 分钟前
DuckDB 性能调优终极指南:打造闪电般的分析体验
python
狼爷28 分钟前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
带派擂总1 小时前
Python全栈开发精华版最全合集(包含各种面试题) Day24_异常和错误
python
金銀銅鐵4 小时前
n^5 和 n 的个位数是否总相等?
python·数学
祎雪双十Gy5 小时前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
小锋java12345 小时前
分享一套锋哥原创的SpringBoot4+Vue3宠物领养网站系统
java
aqi007 小时前
15天学会AI应用开发(九)利用Chroma持久化向量数据
人工智能·python·大模型·ai编程·ai应用
金銀銅鐵7 小时前
借助 Pygame 探索最大公约数的规律
python·数学·游戏