Export Feishu/Lark cloud documents to Markdown
Project description
feishu-docx
Feishu/Lark Docs、Sheet、Bitable → Markdown | AI Agent-friendly knowledge base exporter with OAuth 2.0, CLI, TUI & Claude Skills support
中文 | English
🎯 Why feishu-docx?
Let AI Agents read your Feishu/Lark knowledge base.
- 🤖 Built for AI — Works seamlessly with Claude/GPT Skills for document retrieval
- 📄 Full Coverage — Documents, Spreadsheets, Bitables, Wiki nodes
- 🔐 Authentication — One-time auth, automatic token refresh
- 🎨 Dual Interface — CLI + Beautiful TUI (Textual-based)
- 📦 Zero Config —
pip installand start exporting
⚡ Quick Start (30 seconds)
# Install
pip install feishu-docx
# Configure credentials (one-time)
feishu-docx config set --app-id YOUR_APP_ID --app-secret YOUR_APP_SECRET
# Authorize
feishu-docx auth
# Export!
feishu-docx export "https://my.feishu.cn/wiki/KUIJwaBuGiwaSIkkKJ6cfVY8nSg"
🤖 Claude Skills Support
Enable Claude to access your Feishu knowledge base directly!
This project includes a Claude Skill at .skills/feishu-docx/SKILL.md.
Copy this Skill to your agent project, and Claude can:
- 📖 Read Feishu knowledge base as context
- 🔍 Search and reference internal documents
- 📝 (Planned) Write conversation content back to Feishu
✨ Features
| Feature | Description |
|---|---|
| 📄 Document Export | Docx → Markdown with formatting, images, tables |
| 📊 Spreadsheet Export | Sheet → Markdown tables |
| 📋 Bitable Export | Multidimensional tables → Markdown |
| 📚 Wiki Export | Auto-resolve wiki nodes |
| 🖼️ Auto Image Download | Images saved locally with relative paths |
| 🔐 OAuth 2.0 | Browser-based auth, token persistence |
| 🎨 Beautiful TUI | Terminal UI powered by Textual |
✅ Supported Blocks
This tool currently supports exporting the following Feishu/Lark document components:
| Category | Features | Status | Notes |
|---|---|---|---|
| Basic Text | Headings, Paragraphs, Lists, Tasks (Todo), Code Blocks, Quotes | ✅ | Fully Supported |
| Formatting | Bold, Italic, Strikethrough, Underline, Links, @Mentions | ✅ | Fully Supported |
| Layout | Columns, Callouts, Dividers | ✅ | Fully Supported |
| Tables | Native Tables | ✅ | Export to Markdown/HTML |
| Media | Images, Drawing Boards | ✅ | Drawing boards exported as images |
| Embedded | Spreadsheets (Sheets), Bitable | ✅ | Text content only |
| Special | Synced Blocks | ⚠️ | Original blocks within the same doc only |
| Files | Attachments | ✅ | File name + download link |
📖 Usage
CLI
# Export to specific directory
feishu-docx export "https://xxx.feishu.cn/docx/xxx" -o ./docs
# Use token directly
feishu-docx export "URL" -t your_access_token
# Launch TUI
feishu-docx tui
Python API
from feishu_docx import FeishuExporter
# OAuth
exporter = FeishuExporter(app_id="xxx", app_secret="xxx")
path = exporter.export("https://xxx.feishu.cn/wiki/xxx", "./output")
# Or use token directly
exporter = FeishuExporter.from_token("user_access_token")
content = exporter.export_content("https://xxx.feishu.cn/docx/xxx")
🔐 Feishu App Setup
- Create app at Feishu Open Platform
- Add redirect URL:
http://127.0.0.1:9527/ - Request permissions:
"docx:document:readonly" # 查看云文档
"wiki:wiki:readonly" # 查看知识库
"drive:drive:readonly" # 查看云空间文件(图片下载)
"sheets:spreadsheet:readonly" # 查看电子表格
"bitable:app:readonly" # 查看多维表格
"board:whiteboard:node:read" # 查看白板
"contact:contact.base:readonly" # 获取用户基本信息(@用户名称)
"offline_access" # 离线访问(获取 refresh_token)
- Save credentials:
feishu-docx config set --app-id cli_xxx --app-secret xxx
📖 Commands
| Command | Description |
|---|---|
export <URL> |
Export document to Markdown |
auth |
OAuth authorization |
tui |
Launch TUI interface |
config set |
Set credentials |
config show |
Show configuration |
config clear |
Clear cache |
🗺️ Roadmap
- Document/Sheet/Wiki export
- OAuth 2.0 + Token refresh
- TUI interface
- Claude Skills support
- Batch export entire wiki space
- MCP Server support
- Write to Feishu (create/update docs)
📜 Changelog
See CHANGELOG.md for version history.
📄 License
MIT License - See LICENSE
⭐ Star this repo if you find it helpful!
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file feishu_docx-0.1.4.tar.gz.
File metadata
- Download URL: feishu_docx-0.1.4.tar.gz
- Upload date:
- Size: 37.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
4750be297137f2530519d5a27089e73e97b3e4c332f067cb909087877dcae552
|
|
| MD5 |
2a7aeb904c13fa0d3b606798e9f55e3a
|
|
| BLAKE2b-256 |
3d2c6e5fc7de1cbce0fae569b93649e2830c09dac641ce8a70c2884947cd11f3
|
File details
Details for the file feishu_docx-0.1.4-py3-none-any.whl.
File metadata
- Download URL: feishu_docx-0.1.4-py3-none-any.whl
- Upload date:
- Size: 51.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.11.14
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
7ebb4f853aedc8ade94a6f6dc8e0849a0ab8b2db33d609bef99d589df920462b
|
|
| MD5 |
f2b7d131917aaa88dababdb105f2cd26
|
|
| BLAKE2b-256 |
efb6ee5ef234b93ce22cdc711ecd1653d68036e6a1df5f87be381e043783e11e
|