Skip to main content

Python SDK for Feishu / Lark

Project description

OpenFeishu

OpenFeishu 是一个飞书开放平台的 Python SDK,提供了飞书开放平台的接口封装,方便开发者使用飞书开放平台的接口。

使用

快速开始

FeishuClient 是一个异步客户端,统一管理应用凭证、令牌的自动获取与缓存,以及带自动重试的 HTTP 传输。推荐通过 async with 使用,以便自动释放底层连接。消息接口以接收者为第一个参数(其 ID 类型会自动推断),消息内容为第二个参数;client.im.send 还会根据内容的形态自动推断消息类型(msg_type)。

import asyncio

from feishu import FeishuClient


async def main():
    async with FeishuClient("cli_xxx", "app_secret") as client:
        await client.im.send("oc_xxx", "hello, world!")


asyncio.run(main())

应用凭证也可以通过环境变量 FEISHU_APP_ID / FEISHU_APP_SECRET 提供,此时可省略构造参数:async with FeishuClient() as client: ...

命名空间

各业务能力按资源划分到不同命名空间下,每个命名空间提供「裸动词」式的 CRUD 方法(如 create / get / update / delete / list)。常用入口:

命名空间 说明
client.im 即时消息:发送、回复、编辑、撤回、转发消息
client.contact.users / client.contact.departments 通讯录:用户与部门
client.bitable.tables 多维表格:数据表、字段与记录
client.calendar.events 日历:日程与参与人
client.approval.instances 审批:审批实例与任务
client.drive.files 云空间:文件的上传、下载、复制与删除

此外还有 client.docx(新版文档)、client.sheets(电子表格)、client.wiki(知识库)、client.board.whiteboards(画板)、client.vc(视频会议)、client.task(任务)、client.oauth(用户身份 OAuth)、client.cards(卡片构建器)等命名空间。

async with FeishuClient("cli_xxx", "app_secret") as client:
    user = await client.contact.users.get("ou_xxx", user_id_type="open_id")
    records = await client.bitable.records.list("app_token", "tbl_xxx")

接收事件

要接收飞书推送的事件(如「接收消息」),先用 EventDispatcher 按事件类型注册异步处理函数,Webhook 接收器与长连接两种接入方式共用同一套处理函数。

from feishu.events import EventDispatcher

dispatcher = EventDispatcher()


@dispatcher.on("im.message.receive_v1")
async def on_message(event):
    print(event.event_id)

方式一:Webhook 接收器。 当应用有公网回调地址时,用 create_event_app 生成一个可独立运行的 Starlette 应用,默认带签名新鲜度(防重放)与去重保护,以任意 ASGI 服务器(如 uvicorn)运行即可:

from feishu.events import create_event_app

app = create_event_app(dispatcher, encrypt_key="ek_secret")
# uvicorn module:app

方式二:长连接(WebSocket)。 当应用没有公网回调地址时,用 feishu.ws.WsClient 主动与飞书建立一条持久 WebSocket 连接(对标 Slack 的 Socket Mode),事件经该连接推送:

import asyncio

from feishu.ws import WsClient

ws = WsClient("cli_xxx", "app_secret", dispatcher)
asyncio.run(ws.start())

长连接依赖可选的 websockets 包,可通过 pip install open-feishu[ws] 安装。

安装

从 PyPI 安装最新的稳定版本:

pip install open-feishu

如果需要使用 feishu-mcp 命令,请安装 MCP 可选依赖:

pip install "open-feishu[mcp]"

从源代码安装最新版本:

pip install git+https://github.com/ZhiyuanChen/open-feishu.git

许可证

SPDX-License-Identifier: AGPL-3.0-or-later

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

open_feishu-0.3.0.tar.gz (6.7 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

open_feishu-0.3.0-py3-none-any.whl (482.1 kB view details)

Uploaded Python 3

File details

Details for the file open_feishu-0.3.0.tar.gz.

File metadata

  • Download URL: open_feishu-0.3.0.tar.gz
  • Upload date:
  • Size: 6.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for open_feishu-0.3.0.tar.gz
Algorithm Hash digest
SHA256 f5e2d7f5f8d6e7db2f349ffb3f371bdb3fc1a85cde0f2106fbbd6872721cec84
MD5 920ec978ff6982f3bbb4f8aed398a65e
BLAKE2b-256 88092a9954cbed461d270d11de5e82d6b5b68dd48c811d1689724e4820124d9a

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_feishu-0.3.0.tar.gz:

Publisher: push.yaml on ZhiyuanChen/open-feishu

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file open_feishu-0.3.0-py3-none-any.whl.

File metadata

  • Download URL: open_feishu-0.3.0-py3-none-any.whl
  • Upload date:
  • Size: 482.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for open_feishu-0.3.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7ecbf87c7231b96de55eda510a167d3064626cb2fb4280d1b676bd5212cea0a4
MD5 06f41437b005cf79a4ae19abf0332048
BLAKE2b-256 fe6cc0df1888fc84013628b17b0ae2022576e6ce98662642abf31e7ee19b47eb

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_feishu-0.3.0-py3-none-any.whl:

Publisher: push.yaml on ZhiyuanChen/open-feishu

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page