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.2.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.2.0-py3-none-any.whl (421.4 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: open_feishu-0.2.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.2.0.tar.gz
Algorithm Hash digest
SHA256 367f4b3068b7af4c88973c05e8c20d7b3683cadf24fb8c43fade4322a8140830
MD5 648c2802e89453dc5378b598d1893dd9
BLAKE2b-256 37af69d48ebbe54b0f3556192fb7c6132682083ffca8302bb0dea3df45a1b912

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_feishu-0.2.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.2.0-py3-none-any.whl.

File metadata

  • Download URL: open_feishu-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 421.4 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 18bf5d94dc626173e3238b370fed58b297c0dfaac73ca4be26fa9fe938967a15
MD5 67974777fffe7bcddb3ea3866b840792
BLAKE2b-256 e1959f05587a51de31501ac457f29f7440889500942aeabe502a9c14eab19bb7

See more details on using hashes here.

Provenance

The following attestation bundles were made for open_feishu-0.2.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