Skip to main content

AI-agent-native document engine: generate and chat-edit DOCX, XLSX and PPTX as a Python library, agent tool set, MCP server or hosted service. Korean-first. Sister project of edit2ppt.

Project description

edit2docs

AI-agent-native document engine — DOCX · XLSX · PPTX. Korean-first.

한국어 README · Sister project of edit2ppt (the PPTX pipeline is inherited from it) · Built on ppt-master (MIT)


edit2docs generates complete Office documents from a one-line intent and chat-edits existing files — Word reports, Excel workbooks and PowerPoint decks — always producing natively editable OOXML. One engine, four surfaces:

pip install edit2docs              # library + agent tools + local MCP
pip install "edit2docs[server]"    # + the hosted multi-tenant service

The five verbs

Every surface exposes the same five format-dispatched verbs — the file extension picks the engine:

verb what it does LLM?
generate_doc intent (+ optional sources / PPTX template) → complete document
edit_doc one natural-language edit turn; untouched content stays byte-identical
preview_doc .pptx → per-slide SVG · .docx/.xlsx → markdown
analyze_doc structure outline with the exact addresses set_doc_text needs
set_doc_text deterministic targeted edits (paragraphs / cells / slide text)

1 · Python library

from edit2docs import generate_doc, edit_doc, preview_doc, analyze_doc, set_doc_text

generate_doc("3분기 실적 보고서", output="report.docx")
generate_doc("분기별 매출 정리", output="sales.xlsx", sources=["raw.pdf"])
generate_doc("Q3 영업 결과 임원 보고", output="deck.pptx", template="brand.pptx",
             deck_mode="template_restyle")

r = edit_doc("report.docx", "진행 사항 섹션에 배포 완료 항목을 추가해줘")
print(r.reply, r.operations)

info = analyze_doc("sales.xlsx")               # sheets + sample rows
set_doc_text("sales.xlsx", [{"sheet": "매출", "cell": "B3", "value": 142}])

BYOK: api_key=... or ANTHROPIC_API_KEY. The deterministic verbs need no key. Async variants: async_generate_doc, async_edit_doc.

2 · Agent tools (function calling)

from edit2docs.agent_tools import ANTHROPIC_TOOLS, run_tool

msg = client.messages.create(model="claude-opus-4-7", tools=ANTHROPIC_TOOLS, ...)
for block in msg.content:
    if block.type == "tool_use":
        result = run_tool(block.name, block.input)

3 · Local MCP server (zero infra)

// Claude Desktop / Claude Code / Cursor
{ "mcpServers": { "edit2docs": {
    "command": "edit2docs-mcp",
    "env": { "ANTHROPIC_API_KEY": "sk-ant-..." }
} } }

4 · Hosted service

pip install "edit2docs[server]" then edit2docs serve — the FastAPI service (REST + SSE jobs + hosted MCP) inherited from edit2ppt: multi-tenant assets, job queue, S3-compatible storage, PPTX studio endpoints.

How each format works

  • DOCX — the writer LLM emits a constrained markdown document; a deterministic renderer (python-docx) turns it into styled Word. Edits are paragraph-addressed operations (replace / insert_after / delete, table cells by row/col) so untouched paragraphs keep their formatting.
  • XLSX — the designer LLM emits a YAML sheet spec (sheets / headers / rows / number formats, formulas allowed); openpyxl renders styled sheets. Edits are set_cell / append_rows / add_sheet with staleness guards.
  • PPTX — the full multi-stage deck pipeline inherited from edit2ppt: strategist → per-page SVG → native DrawingML, user-PPTX templates (restyle/extend), chat-edit with slide recompose, per-paragraph text edits incl. table cells.

Every LLM planner follows the same contract: fenced reply + edit_plan blocks, one retry with a format reminder, and an honest reply (instead of a silent no-op) when planning fails. Korean-native throughout: Hangul-aware widths, lang="ko-KR" OOXML runs, bilingual errors.

License

MIT. PPTX core forked from ppt-master (MIT) via edit2ppt.

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

edit2docs-0.1.0.tar.gz (5.7 MB view details)

Uploaded Source

Built Distribution

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

edit2docs-0.1.0-py3-none-any.whl (10.6 MB view details)

Uploaded Python 3

File details

Details for the file edit2docs-0.1.0.tar.gz.

File metadata

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

File hashes

Hashes for edit2docs-0.1.0.tar.gz
Algorithm Hash digest
SHA256 3d9eac996aef11aaef14a47bdc593165289469e7bf01712efd928dae67753062
MD5 88e93c61f936203d13c843d8595e0e37
BLAKE2b-256 2603b5113c06bd792a80b988e1e50bb1c946c0ea1ce90411623a400319b9030d

See more details on using hashes here.

Provenance

The following attestation bundles were made for edit2docs-0.1.0.tar.gz:

Publisher: publish.yml on CocoRoF/edit2docs

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

File details

Details for the file edit2docs-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: edit2docs-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 10.6 MB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for edit2docs-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 71e6190caf7220acac91498615778f0447c85e681e700d6ab28d6cc7e0daace0
MD5 c4989e5581859b99b786b61c114254a3
BLAKE2b-256 5cb502ea23b0869262ca957a252a36b7778cc69cab522ff622901ac17cf9af40

See more details on using hashes here.

Provenance

The following attestation bundles were made for edit2docs-0.1.0-py3-none-any.whl:

Publisher: publish.yml on CocoRoF/edit2docs

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