【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)
相关推荐
笨拙的老猴子10 分钟前
Spring AI 实战教程(七):Agent 智能体 —— 用电商购物助手学透自主规划与工具执行
java·人工智能·spring
辰尘_星启10 分钟前
【Linux】Python Socket编程指南
linux·python·socket·系统·通信
月落归舟14 分钟前
深入解析Java基础之基础
java·开发语言
折哥的程序人生 · 物流技术专研14 分钟前
《Java 100 天进阶之路》第20篇:Java初始化、构造器、对象创建的过程
java·开发语言·后端·面试
南宫萧幕19 分钟前
基于 Simulink 与 Python 联合仿真的 eVTOL 强化学习全链路实战
开发语言·人工智能·python·算法·机器学习·控制
电魂泡哥21 分钟前
CMS垃圾回收
java·jvm·算法
Amctwd39 分钟前
【Python】从Excel中按行提取图片
java·python·excel
张二娃同学1 小时前
第08篇_RNN_LSTM_GRU序列模型
人工智能·python·rnn·深度学习·神经网络·gru·lstm
财经资讯数据_灵砚智能1 小时前
基于全球经济类多源新闻的NLP情感分析与数据可视化(夜间-次晨)2026年5月13日
大数据·人工智能·python·信息可视化·语言模型·自然语言处理
啃臭1 小时前
AOP和反射
java·spring boot