OfficeCLI/README_zh.md

28 KiB
Raw Blame History

OfficeCLI

OfficeCLI 是全球首个、也是最好的专为 AI 智能体设计的命令行工具。

让任何 AI 智能体完全掌控 Word、Excel 和 PowerPoint -- 只需一行代码。

开源免费。单一可执行文件。无需安装 Office。零依赖。全平台运行。

GitHub Release License

English | 中文 | 日本語 | 한국어

在 AionUi 上使用 OfficeCLI 的 PPT 制作过程

AionUi 上使用 OfficeCLI 的 PPT 制作过程

PowerPoint 演示文稿

OfficeCLI 设计演示 (PowerPoint) OfficeCLI 商务演示 (PowerPoint) OfficeCLI 科技演示 (PowerPoint)
OfficeCLI 太空演示 (PowerPoint) OfficeCLI 游戏演示 (PowerPoint) OfficeCLI 创意演示 (PowerPoint)

Word 文档

OfficeCLI 学术论文 (Word) OfficeCLI 项目建议书 (Word) OfficeCLI 年度报告 (Word)

Excel 电子表格

OfficeCLI 预算跟踪 (Excel) OfficeCLI 成绩管理 (Excel) OfficeCLI 销售仪表盘 (Excel)

以上所有文档均由 AI 智能体使用 OfficeCLI 全自动创建 — 无模板、无人工编辑。

AI 智能体 — 一行搞定

把这行粘贴到你的 AI 智能体对话框 — 它会自动读取技能文件并完成安装:

curl -fsSL https://officecli.ai/SKILL.md

就这一步。技能文件会教智能体如何安装二进制文件并使用所有命令。

技术细节: OfficeCLI 附带 SKILL.md,涵盖命令语法、架构设计和常见陷阱。安装后,您的智能体可以立即创建、读取和修改任何 Office 文档。

普通用户

方式 A — 图形界面: 安装 AionUi — 一款桌面应用,用自然语言就能创建和编辑 Office 文档,底层由 OfficeCLI 驱动。只需描述你想要什么AionUi 帮你搞定。

方式 B — 命令行:GitHub Releases 下载对应平台的二进制文件,然后运行:

officecli install

该命令会将二进制文件复制到 PATH并自动将 officecli 技能文件安装到检测到的所有 AI 编程助手 — Claude Code、Cursor、Windsurf、GitHub Copilot 等。您的智能体可以立即创建、读取和编辑 Office 文档,无需额外配置。

开发者 — 30 秒亲眼看到效果

# 1. 安装macOS / Linux
curl -fsSL https://raw.githubusercontent.com/iOfficeAI/OfficeCLI/main/install.sh | bash
# Windows (PowerShell): irm https://raw.githubusercontent.com/iOfficeAI/OfficeCLI/main/install.ps1 | iex

# 2. 创建一个空白 PowerPoint
officecli create deck.pptx

# 3. 启动实时预览 — 浏览器自动打开 http://localhost:26315
officecli watch deck.pptx --port 26315

# 4. 打开另一个终端,添加一页幻灯片 — 浏览器即时刷新
officecli add deck.pptx / --type slide --prop title="Hello, World!"

就这么简单。你执行的每一条 addsetremove 命令都会实时刷新预览。继续尝试吧 — 浏览器就是你的实时反馈窗口。

快速开始

# 创建演示文稿并添加内容
officecli create deck.pptx
officecli add deck.pptx / --type slide --prop title="Q4 Report" --prop background=1A1A2E
officecli add deck.pptx '/slide[1]' --type shape \
  --prop text="Revenue grew 25%" --prop x=2cm --prop y=5cm \
  --prop font=Arial --prop size=24 --prop color=FFFFFF

# 查看大纲
officecli view deck.pptx outline
# → Slide 1: Q4 Report
# →   Shape 1 [TextBox]: Revenue grew 25%

# 查看 HTML — 在浏览器中打开渲染预览,无需启动服务器
officecli view deck.pptx html

# 获取任意元素的结构化 JSON
officecli get deck.pptx '/slide[1]/shape[1]' --json
{
  "tag": "shape",
  "path": "/slide[1]/shape[1]",
  "attributes": {
    "name": "TextBox 1",
    "text": "Revenue grew 25%",
    "x": "720000",
    "y": "1800000"
  }
}

为什么选择 OfficeCLI

以前需要 50 行 Python 和 3 个独立库:

from pptx import Presentation
from pptx.util import Inches, Pt
prs = Presentation()
slide = prs.slides.add_slide(prs.slide_layouts[0])
title = slide.shapes.title
title.text = "Q4 Report"
# ... 还有 45 行 ...
prs.save('deck.pptx')

现在只需一条命令:

officecli add deck.pptx / --type slide --prop title="Q4 Report"

OfficeCLI 能做什么:

  • 创建 文档 -- 空白文档或带内容的文档
  • 读取 文本、结构、样式、公式 -- 纯文本或结构化 JSON
  • 分析 格式问题、样式不一致和结构缺陷
  • 修改 任意元素 -- 文本、字体、颜色、布局、公式、图表、图片
  • 重组 内容 -- 添加、删除、移动、复制跨文档元素
格式 读取 修改 创建
Word (.docx)
Excel (.xlsx)
PowerPoint (.pptx)

Word段落文本片段表格样式页眉/页脚图片公式批注脚注水印书签目录图表超链接表单域内容控件 (SDT)文档属性

Excel单元格、公式(内置 150+ 函数自动求值)、工作表表格条件格式图表数据透视表多字段、日期分组、showDataAs、排序、总计、分类汇总命名范围数据验证图片迷你图批注自动筛选形状、CSV/TSV 导入、$Sheet:A1 单元格寻址

PowerPoint幻灯片形状图片表格图表动画morph 过渡3D 模型(.glb幻灯片缩放公式主题连接线视频/音频组合备注占位符

使用场景

开发者:

  • 从数据库或 API 自动生成报告
  • 批量处理文档(批量查找/替换、样式更新)
  • 在 CI/CD 环境中构建文档流水线(从测试结果生成文档)
  • Docker/容器化环境中的无头 Office 自动化

AI 智能体:

  • 根据用户提示生成演示文稿(见上方示例)
  • 从文档提取结构化数据到 JSON
  • 交付前验证和检查文档质量

团队:

  • 克隆文档模板并填充数据
  • CI/CD 流水线中的自动化文档验证

安装

单一自包含可执行文件,.NET 运行时已内嵌 -- 无需安装任何依赖,无需管理运行时。

一键安装:

# macOS / Linux
curl -fsSL https://raw.githubusercontent.com/iOfficeAI/OfficeCLI/main/install.sh | bash

# Windows (PowerShell)
irm https://raw.githubusercontent.com/iOfficeAI/OfficeCLI/main/install.ps1 | iex

或手动下载 GitHub Releases

平台 文件名
macOS Apple Silicon officecli-mac-arm64
macOS Intel officecli-mac-x64
Linux x64 officecli-linux-x64
Linux ARM64 officecli-linux-arm64
Windows x64 officecli-win-x64.exe
Windows ARM64 officecli-win-arm64.exe

验证安装:officecli --version

或从已下载的二进制文件自安装(直接运行 officecli 也会触发安装):

officecli install    # 显式安装
officecli            # 直接运行也会触发安装

OfficeCLI 会在后台自动检查更新。通过 officecli config autoUpdate false 关闭,或通过 OFFICECLI_SKIP_UPDATE=1 跳过单次检查。配置文件位于 ~/.officecli/config.json

核心功能

实时预览

watch 启动本地 HTTP 服务器,实时预览 PowerPoint 文件。每次修改自动刷新浏览器 — 非常适合与 AI 智能体配合做迭代设计。

officecli watch deck.pptx
# 打开 http://localhost:26315 — 每次 set/add/remove 自动刷新

支持形状、图表、公式、3D 模型Three.js、morph 过渡、缩放导航和所有形状效果的渲染。

驻留模式与批量执行

驻留模式将文档保持在内存中,批量模式在一次打开/保存周期内执行多条命令。

# 驻留模式 — 通过命名管道通信,延迟接近零
officecli open report.docx
officecli set report.docx /body/p[1]/r[1] --prop bold=true
officecli set report.docx /body/p[2]/r[1] --prop color=FF0000
officecli close report.docx

# 批量模式 — 原子化多命令执行(默认遇到第一个错误即停止)
echo '[{"command":"set","path":"/slide[1]/shape[1]","props":{"text":"Hello"}},
      {"command":"set","path":"/slide[1]/shape[2]","props":{"fill":"FF0000"}}]' \
  | officecli batch deck.pptx --json

# 内联 batch无需标准输入
officecli batch deck.pptx --commands '[{"op":"set","path":"/slide[1]/shape[1]","props":{"text":"Hi"}}]'

# 使用 --force 跳过错误继续执行
officecli batch deck.pptx --input updates.json --force --json

三层架构

从简单开始,仅在需要时深入。

用途 命令
L1读取 内容的语义视图 viewtext、annotated、outline、stats、issues、html
L2DOM 结构化元素操作 getquerysetaddremovemoveswap
L3原始 XML XPath 直接访问 — 通用兜底 rawraw-setadd-partvalidate
# L1 — 高级视图
officecli view report.docx annotated
officecli view budget.xlsx text --cols A,B,C --max-lines 50

# L2 — 元素级操作
officecli query report.docx "run:contains(TODO)"
officecli add budget.xlsx / --type sheet --prop name="Q2 Report"
officecli move report.docx /body/p[5] --to /body --index 1

# L3 — L2 不够时用原始 XML
officecli raw deck.pptx '/slide[1]'
officecli raw-set report.docx document \
  --xpath "//w:p[1]" --action append \
  --xml '<w:r><w:t>Injected text</w:t></w:r>'

AI 集成

MCP 服务器

内置 MCP 服务器 — 一条命令注册:

officecli mcp claude       # Claude Code
officecli mcp cursor       # Cursor
officecli mcp vscode       # VS Code / Copilot
officecli mcp lmstudio     # LM Studio
officecli mcp list         # 查看注册状态

通过 JSON-RPC 暴露所有文档操作 — 无需 shell 访问。

直接 CLI 集成

两步将 OfficeCLI 集成到任何 AI 智能体:

  1. 安装二进制文件 -- 一条命令(见安装
  2. 完成。 OfficeCLI 自动检测您的 AI 工具Claude Code、GitHub Copilot、Codex通过检查已知配置目录并安装技能文件。您的智能体可以立即创建、读取和修改任何 Office 文档。
手动配置(可选)

如果自动安装未覆盖您的环境,可以手动安装技能文件:

直接将 SKILL.md 提供给智能体:

curl -fsSL https://officecli.ai/SKILL.md

安装为 Claude Code 本地技能:

curl -fsSL https://officecli.ai/SKILL.md -o ~/.claude/skills/officecli.md

其他智能体:SKILL.md 的内容添加到智能体的系统提示词或工具描述中。

从任意语言调用:

# Python
import subprocess, json
def cli(*args): return subprocess.check_output(["officecli", *args], text=True)
cli("create", "deck.pptx")
cli("set", "deck.pptx", "/slide[1]/shape[1]", "--prop", "text=Hello")
// JavaScript
const { execFileSync } = require('child_process')
const cli = (...args) => execFileSync('officecli', args, { encoding: 'utf8' })
cli('set', 'deck.pptx', '/slide[1]/shape[1]', '--prop', 'text=Hello')

每个命令都支持 --json 输出结构化数据。基于路径的寻址让智能体无需理解 XML 命名空间。

为什么智能体偏爱 OfficeCLI

  • 确定性 JSON 输出 -- 每个命令都支持 --json,返回结构一致的数据。无需正则解析。
  • 基于路径的寻址 -- 每个元素都有稳定的路径(/slide[1]/shape[2])。智能体无需理解 XML 命名空间即可导航文档。注意:路径使用 OfficeCLI 自有语法1-based 索引,元素本地名称),非 XPath。
  • 渐进式复杂度 -- 从 L1读取开始升级到 L2修改仅在必要时回退到 L3原始 XML。最大限度减少 token 消耗。
  • 自愈式工作流 -- validateview issues 和帮助系统让智能体无需人工干预即可检测问题并自行修正。
  • 内置帮助 -- 属性名或取值格式不确定时,运行 officecli <format> set <element> 即可查询,无需猜测。
  • 自动安装 -- 无需手动配置技能文件。OfficeCLI 自动检测您的 AI 工具并完成配置。

内置帮助

不确定属性名时,用分层帮助查询:

officecli pptx set              # 全部可设置元素与属性
officecli pptx set shape        # 某一类元素的详细说明
officecli pptx set shape.fill   # 单个属性格式与示例
officecli docx query            # 选择器说明:属性匹配、:contains、:has() 等

pptx 换成 docxxlsx;动词包括 viewgetquerysetaddraw

运行 officecli --help 查看完整概览。

JSON 输出格式

所有命令均支持 --json。常见响应格式:

单个元素get --json

{"tag": "shape", "path": "/slide[1]/shape[1]", "attributes": {"name": "TextBox 1", "text": "Hello"}}

元素列表query --json

[
  {"tag": "paragraph", "path": "/body/p[1]", "attributes": {"style": "Heading1", "text": "Title"}},
  {"tag": "paragraph", "path": "/body/p[5]", "attributes": {"style": "Heading1", "text": "Summary"}}
]

错误 返回结构化错误对象,包含错误码、建议修正和可用值:

{
  "success": false,
  "error": {
    "error": "Slide 50 not found (total: 8)",
    "code": "not_found",
    "suggestion": "Valid Slide index range: 1-8"
  }
}

错误码:not_foundinvalid_valueunsupported_propertyinvalid_pathunsupported_typemissing_propertyfile_not_foundfile_lockedinvalid_selector。属性名支持自动纠错 -- 拼错属性名时会返回最接近的匹配建议。

错误恢复 -- 智能体通过检查可用元素自行修正:

# 智能体尝试无效路径
officecli get report.docx /body/p[99] --json
# 返回: {"success": false, "error": {"error": "...", "code": "not_found", "suggestion": "..."}}

# 智能体通过查看可用元素自行修正
officecli get report.docx /body --depth 1 --json
# 返回可用子元素列表,智能体选择正确路径

变更确认setaddremovemovecreate 使用 --json

{"success": true, "path": "/slide[1]/shape[1]"}

运行 officecli --help 查看退出码和错误格式的完整说明。

对比

OfficeCLI Microsoft Office LibreOffice python-docx / openpyxl
开源免费 ✓ (Apache 2.0) ✗(付费授权)
AI 原生 CLI + JSON
零安装(单一可执行文件) ✗(需 Python + pip
任意语言调用 ✓ (CLI) ✗ (COM/Add-in) ✗ (UNO API) 仅 Python
基于路径的元素访问
原始 XML 兜底 部分支持
实时预览
无头 / CI 环境 部分支持
跨平台 Windows/Mac
Word + Excel + PowerPoint 需要多个库

更新与配置

officecli config autoUpdate false              # 关闭自动更新检查
OFFICECLI_SKIP_UPDATE=1 officecli ...          # 单次调用跳过检查CI

命令参考

命令 说明
create 创建空白 .docx、.xlsx 或 .pptx根据扩展名判断类型
view 查看内容(模式:outlinetextannotatedstatsissueshtml
get 获取元素及子元素(--depth N--json
query CSS 风格查询([attr=value]:contains():has() 等)
set 修改元素属性
add 添加元素(或通过 --from <path> 克隆)
remove 删除元素
move 移动元素(--to <parent>--index N--after <path>--before <path>
swap 交换两个元素
validate OpenXML 模式校验
batch 单次打开/保存周期内执行多条操作stdin、--input--commands;默认遇到第一个错误停止,--force 跳过错误继续)
merge 模板合并 — 用 JSON 数据替换 {{key}} 占位符
watch 在浏览器中实时 HTML 预览,自动刷新
mcp 启动 MCP 服务器,用于 AI 工具集成
raw 查看文档部件的原始 XML
raw-set 通过 XPath 修改原始 XML
add-part 添加新的文档部件(页眉、图表等)
open 启动驻留模式(文档保持在内存中)
close 保存并关闭驻留模式
install 安装二进制文件 + 技能文件 + MCPallclaudecursor 等)
config 获取或设置配置
<format> <command> 内置帮助(如 officecli pptx set shape

端到端工作流示例

典型的智能体自愈式工作流:创建演示文稿、填充内容、验证并修复问题 -- 全程无需人工干预。

# 1. 创建
officecli create report.pptx

# 2. 添加内容
officecli add report.pptx / --type slide --prop title="Q4 Results"
officecli add report.pptx '/slide[1]' --type shape \
  --prop text="Revenue: $4.2M" --prop x=2cm --prop y=5cm --prop size=28
officecli add report.pptx / --type slide --prop title="Details"
officecli add report.pptx '/slide[2]' --type shape \
  --prop text="Growth driven by new markets" --prop x=2cm --prop y=5cm

# 3. 验证
officecli view report.pptx outline
officecli validate report.pptx

# 4. 修复发现的问题
officecli view report.pptx issues --json
# 根据输出修复问题,例如:
officecli set report.pptx '/slide[1]/shape[1]' --prop font=Arial

模板合并

用 JSON 数据替换文档中的 {{key}} 占位符 -- 支持段落、表格单元格、形状、页眉页脚、图表标题等所有文本内容。

# 内联 JSON 数据
officecli merge template.docx output.docx '{"name":"Alice","dept":"Sales","date":"2026-03-30"}'

# 从 JSON 文件读取数据
officecli merge template.pptx report.pptx data.json

# Excel 模板
officecli merge budget-template.xlsx q4-budget.xlsx '{"quarter":"Q4","year":"2026"}'

单位与颜色

所有尺寸和颜色属性均接受灵活的输入格式:

类型 支持的格式 示例
尺寸 cm、in、pt、px 或原始 EMU 2cm1in72pt96px914400
颜色 十六进制、命名色、RGB、主题色 #FF0000FF0000redrgb(255,0,0)accent1
字号 纯数字或带 pt 后缀 1414pt10.5pt
间距 pt、cm、in 或倍数 12pt0.5cm1.5x150%

常用模式

# 替换 Word 文档中所有 Heading1 文本
officecli query report.docx "paragraph[style=Heading1]" --json | ...
officecli set report.docx /body/p[1]/r[1] --prop text="New Title"

# 将所有幻灯片内容导出为 JSON
officecli get deck.pptx / --depth 2 --json

# 批量更新 Excel 单元格
officecli batch budget.xlsx --input updates.json --json

# 导入 CSV 数据到 Excel 工作表
officecli add budget.xlsx / --type sheet --prop name="Q1 Data" --prop csv=sales.csv

# 模板合并批量生成报告
officecli merge invoice-template.docx invoice-001.docx '{"client":"Acme","total":"$5,200"}'

# 交付前检查文档质量
officecli validate report.docx && officecli view report.docx issues --json

文档

Wiki 提供了每个命令、元素类型和属性的详细指南:

从源码构建

编译需要 .NET 10 SDK。输出为自包含的原生二进制文件 -- .NET 已内嵌,运行时无需安装。

./build.sh

许可证

Apache License 2.0

欢迎通过 GitHub Issues 提交 Bug 报告和贡献代码。


如果觉得 OfficeCLI 好用,请在 GitHub 上点个 Star — 帮助更多人发现这个项目。

OfficeCLI.AI | GitHub