【保姆式】python调用api通过机器人发送文件到飞书指定群聊

当前飞书webhook机器人还不支持发送文件类型的群消息,它目前仅支持文本,富文本,卡片等文字类型的数据。

我们可以申请创建一个机器人应用来实现群发送文件消息。

创建飞书应用

创建飞书应用、配置权限、添加机器人

  1. 来到飞书开发者后台

创建企业自建应用

输入名称、描述

  1. 创建应用后,需要开通一系列权限,然后发布。由管理员审核通过后,才可使用

    在上述位置下添加下述权限并开通

  2. 创建机器人

    在上述位置添加好机器人

  3. 在你要发送的群里中添加刚刚创建的机器人(我这的机器人取名为"推送报表")

  4. 最后提交发布, 在凭证和基础信息这里获取

app id

app secret

调用API上传文件

流程顺序如下:通过app_id,app_secret获取token -> 上传文件(获取文件id)-> 获取群聊chat_id -> 通过文件id将文件上传到指定chat_id

  1. 获取token
python 复制代码
def get_token():
    """ 获取飞书 access_token """
    
    url = "https://open.feishu.cn/open-apis/auth/v3/tenant_access_token/internal/"
    headers = {
        "Content-Type": "application/json"
    }
    data = {
        "app_id": APP_ID,
        "app_secret": APP_SECRET
    }
    response = requests.post(url, headers=headers, json=data)
    if response.status_code == 200:
        return response.json()["tenant_access_token"]
    else:
        return ""
  1. 上传文件到飞书,并获取文件id
python 复制代码
def upload_file(file_name, file_path):
    """ 上传文件到飞书 """
    
    url = "https://open.feishu.cn/open-apis/im/v1/files"
    headers = {
        "Authorization": "Bearer "+get_token()
    }
    form = {
        "file_type": "stream",
        "file_name": file_name,
        "file": (file_name, open(file_path, "rb"), "text/plain")
    }
    multi_form = MultipartEncoder(form)
    headers["Content-Type"] = multi_form.content_type
    response = requests.post(url, headers=headers, data=multi_form)
    if response.status_code == 200 and response.json().get("code") == 0:
        # print(f"上传文件到飞书成功,msg={response.json()},{file_path=}")
        media_id = response.json().get("data", {}).get("file_key")
        return media_id
    else:
        return "" 
  1. 获取群chat_id
    有两种方式,通过api,或者直接通过平台粘贴对应群聊id,这里使用后者,因为是发送到固定群聊
    去到api调试页面,按照如下操作获取对应群聊chat_id
  2. 发送文件到群里
python 复制代码
def send_file(file_path, media_id=None):
    """机器人应用上传文件"""
    if not media_id:
        media_id = upload_file(file_name=file_path, file_path=file_path)
        time.sleep(1)
    url = 'https://open.feishu.cn/open-apis/im/v1/messages?receive_id_type=chat_id'
    msgContent = {
        "file_key": media_id
    }
    form = {
        "content": json.dumps(msgContent),
        "msg_type": "file",
        "receive_id": CHAT_ID
    }
    headers = {
        'Authorization': 'Bearer ' + get_token()
    }
    response = requests.post(url=url, data=json.dumps(form), headers=headers)
    print(response.json())

完成文件发送

相关推荐
xixihaha13244 小时前
将Python Web应用部署到服务器(Docker + Nginx)
jvm·数据库·python
7yewh4 小时前
jetson_yolo_deployment 01_linux_dev_env
linux·嵌入式硬件·yolo·机器人·嵌入式
xixihaha13244 小时前
Python游戏中的碰撞检测实现
jvm·数据库·python
HyperAI超神经5 小时前
AI驱动量子精修,卡内基梅隆大学等提出AQuaRef,首次用量子力学约束精修蛋白质全原子模型
人工智能·深度学习·机器学习·架构·机器人·cpu·量子计算
ID_180079054735 小时前
模拟1688商品详情的Python API实现,返回符合风格的JSON数据
开发语言·python·json
程序员小远5 小时前
软件测试之功能测试详解
自动化测试·软件测试·python·功能测试·测试工具·职场和发展·测试用例
我的xiaodoujiao6 小时前
API接口自动化测试详细图文教程学习系列1--序章
python·学习·pytest
ZhengEnCi6 小时前
P1B-Python环境配置基础完全指南-Windows系统安装与验证
python
m0_716667076 小时前
NumPy入门:高性能科学计算的基础
jvm·数据库·python
带娃的IT创业者7 小时前
Weclaw 请求路由实战:一个 request_id 如何在 800 个并发连接中精准找到目标浏览器?
python·websocket·fastapi·架构设计·实时通信·openclaw·weclaw