Thin Python SDK for the officecli resident pipe — forwards officecli commands to a running resident, no per-command process spawn.
Project description
officecli — Python SDK
A thin Python SDK for the officecli resident pipe. It does one thing: forward an officecli command to a running resident over its named pipe and hand back the response — no per-command process spawn, so a loop of edits is ~hundreds of times faster than shelling out to the CLI per command.
"Thin" is the point: there is no second vocabulary to learn. A command is the
same dict you'd put in an officecli batch list; the SDK just carries it over the
pipe. Anything a doc.set_cell(...) / doc.add_paragraph(...) method would do is
fully supported — you just spell it doc.send({"command": "set", ...}), with
the exact same effect. One uniform verb instead of dozens of per-element named
methods: same power, nothing extra to memorize, and new officecli features work
the day they ship without an SDK update.
Requirement: the officecli CLI must be installed
pip install officecli-sdk installs only this SDK (the Python library). It
shells out to the officecli binary, which must be installed separately and on
your PATH (Homebrew, etc.). If officecli --version works in your shell, you're
set.
Install
pip install officecli-sdk # once published — note: import name is `officecli`
# or, from a checkout of this repo:
pip install ./sdk/python
The pip/distribution name is officecli-sdk, but you import officecli
(distribution name ≠ import name, like pip install pillow → import PIL).
Zero third-party dependencies (standard library only).
Quickstart
import officecli
# create() makes a new file and returns a live session handle;
# open() does the same for an existing file. Both return a Document.
with officecli.create("report.xlsx", "--force") as doc:
doc.send({"command": "set", "path": "/Sheet1/A1",
"props": {"text": "Region", "bold": "true"}})
doc.send({"command": "set", "path": "/Sheet1/B1", "props": {"formula": "=SUM(B2:B9)"}})
# read one back (returns the parsed JSON envelope)
node = doc.send({"command": "get", "path": "/Sheet1/A1"})
print(node["data"]["results"][0]["text"]) # -> Region
# many edits in ONE pipe round-trip
doc.batch([
{"command": "set", "path": "/Sheet1/A2", "props": {"text": "North"}},
{"command": "set", "path": "/Sheet1/A3", "props": {"text": "South"}},
])
doc.send({"command": "save"})
# leaving `with` closes the resident (which flushes to disk)
# borrow an already-running resident without owning it: skip `with`/close()
d = officecli.open("report.xlsx")
print(d.send({"command": "view", "mode": "stats"}, as_json=False))
See demo.py for a fuller example.
The command dict
send(item) and batch([item, ...]) take the officecli batch-item shape:
{ "command": "set", // or "op"; picks the officecli command
"path": "/Sheet1/A1", // every key except command/op/props is forwarded
"props": { "text": "hi" } } // verbatim as a command argument
Keys are officecli's own batch fields (command/op, path, parent, type,
index, after, before, to, selector, mode, depth, part, xpath,
action, xml) plus a nested props. The client maintains no field list of its
own — run officecli help (or see the batch docs) for the full reference.
send(..., as_json=False) requests plain-text output (e.g. view / raw /
dump), mirroring the CLI's --json toggle.
Errors & resilience
- Transport/process failures raise
officecli.OfficeCliError(.codecarries the exit code). Business outcomes (e.g.validatefailing, a bad path) are not exceptions — they live in the returned envelope'ssuccessfield, same as the CLI's exit code. - If the resident has gone (crash, idle-timeout, missing pipe),
send/batchtransparently restart it and retry once. If it's alive but the pipe is unresponsive (busy), they raise rather than risk racing the live resident.
Versioning
This client derives the resident's pipe address from the document path the same way officecli does. That derivation is the one piece coupled to officecli internals, so keep the client version compatible with your installed officecli.
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
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 officecli_sdk-0.1.1.tar.gz.
File metadata
- Download URL: officecli_sdk-0.1.1.tar.gz
- Upload date:
- Size: 11.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a7ccf41fb378c38922175849c8783b44ffebaf999865f1c06465ea4ad05b6d31
|
|
| MD5 |
4e659d3653f1495a8f90e1d1201bf949
|
|
| BLAKE2b-256 |
7e000b11eaf6592df22ea99d32678a5569d11feef949cdf98dd61a975924bd43
|
File details
Details for the file officecli_sdk-0.1.1-py3-none-any.whl.
File metadata
- Download URL: officecli_sdk-0.1.1-py3-none-any.whl
- Upload date:
- Size: 11.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.14.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8f463536c3e85bb0e306c17763bb5c0d9a4ab5c39d16a9094feef4a0782cbb48
|
|
| MD5 |
b4f547f6b0ca6e1e3fc13aa66c51b938
|
|
| BLAKE2b-256 |
d0742a7470a41ad68b7781bdf38bc1d38ac92a284fa95b81d1b209063fcf5646
|