【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)
相关推荐
弹简特2 小时前
【JavaEE28-后端部分】Spring AOP 通知详解——五种“增强时机”,一网打尽
java·spring·spring aop
Dxy12393102162 小时前
Python转Word为PDF:办公自动化的高效利器
python·pdf·word
lulu12165440782 小时前
谷歌Gemma 4实战指南:Apache 2.0开源,移动端AI新时代来临
java·开发语言·人工智能·开源·apache·ai编程
Thomas.Sir2 小时前
第十章:RAG知识库开发之【LangSmith 从入门到精通:构建生产级 LLM 应用的全链路可观测性平台】
人工智能·python·langsmith·langchian
初心未改HD2 小时前
从Java转行大模型应用,Agent应用开发,Function Calling学习
人工智能·python
程序员阿明2 小时前
spring boot在普通方法中获取HttpServletRequest及其使用的方式
java·spring boot·后端
花千树-0102 小时前
Spring Boot 启动慢排查与优化实战指南
java·spring boot·后端·spring
小江的记录本2 小时前
【Docker】《 Docker 高频常用命令速查表 》
java·前端·后端·http·docker·容器·eureka
tigerlib2 小时前
vscode python环境调试,不能调到环境内部,怎么解决
ide·vscode·python