【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)
相关推荐
QC班长7 小时前
Maven公司私库配置踩坑点
java·服务器·maven·intellij-idea
kishu_iOS&AI7 小时前
深度学习 —— 损失函数
人工智能·pytorch·python·深度学习·线性回归
Makoto_Kimur7 小时前
java开发面试-AI Coding速成
java·开发语言
好运的阿财7 小时前
OpenClaw工具拆解之canvas+message
人工智能·python·ai编程·openclaw·openclaw工具
wengqidaifeng8 小时前
python启航:1.基础语法知识
开发语言·python
观北海8 小时前
Windows 平台 Python 极简 ORB-SLAM3 Demo,从零实现实时视觉定位
开发语言·python·动态规划
FreakStudio8 小时前
做了个Claude Code CLI 电子宠物:程序员的实体监工代码搭子
python·单片机·嵌入式·面向对象·并行计算·电子diy·电子计算机
wuqingshun3141598 小时前
说说mybatis的缓存机制
java·缓存·mybatis
柴米油盐那点事儿8 小时前
python+mysql+bootstrap条件搜索分页
python·mysql·flask·bootstrap
空中海8 小时前
Kubernetes 生产实践、可观测性与扩展入门
java·贪心算法·kubernetes