Skip to main content

Univer Use: LangGraph-powered agent utilities and tools for Univer spreadsheets

Project description

Univer Use

LangGraph-powered agent utilities and tools for Univer spreadsheets. This library provides a ready-to-use graph entrypoint and helper tools to build agents that operate against Univer via Univer-MCP.

Features

  • LangGraph graph entrypoint: univer_use/graph.py:build_graph
  • Spreadsheet action agent with MCP tools
  • Prompt templates packaged with the library

Install You can install this package using either name (both are the same package):

Option 1: univer-use

  • pip: pip install univer-use
  • uv: uv add univer-use
  • Poetry: poetry add univer-use

Option 2: spreadsheet-use

  • pip: pip install spreadsheet-use
  • uv: uv add spreadsheet-use
  • Poetry: poetry add spreadsheet-use

Note: Both univer-use and spreadsheet-use provide identical functionality. Choose whichever name you prefer.

Requirements

  • Python 3.11+
  • Credentials via environment or .env (python-dotenv):
    • OPENROUTER_API_KEY – API key for your OpenRouter-compatible provider
    • OPENROUTER_ENDPOINT – Base URL for the provider endpoint
    • UNIVER_API_KEY – Univer API key (if required by your MCP setup)

Quickstart Minimal example to compile and run the graph once:

import asyncio
# Both imports work the same way:
# from univer_use import build_graph
from spreadsheet_use import build_graph

async def main():
    graph = await build_graph()
    # Provide initial state. At minimum, include a conversation_id.
    state = {
        "messages": [],
        "conversation_id": "default",
    }
    result = await graph.ainvoke(state)
    print(result)

asyncio.run(main())

Run Locally with LangGraph CLI The repo includes a local dev config that uses the build_graph entrypoint:

langgraph dev --config examples/sheet_edit/langgraph.json --debug-port 5678 --allow-blocking

This uses the graph at univer_use/graph.py:build_graph. Set env vars in .env or your shell before running. See examples/sheet_edit/.env for an example.

Development

Setup

  • Install dependencies: uv sync

Adding Dependencies Simply use standard dependency management commands:

# Add a runtime dependency
uv add package-name

# Add a development dependency  
uv add --dev package-name

Building & Testing

  • Run tests: uv run pytest -q
  • Build both packages: make build-both

Available Make Commands Run make help to see all available commands for development.

Package Architecture

  • univer-use: The main package containing all functionality
  • spreadsheet-use: A lightweight alias package that depends on univer-use

License MIT. See LICENSE.

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

univer_use-0.1.1a5.tar.gz (141.5 kB view details)

Uploaded Source

Built Distribution

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

univer_use-0.1.1a5-py3-none-any.whl (20.4 kB view details)

Uploaded Python 3

File details

Details for the file univer_use-0.1.1a5.tar.gz.

File metadata

  • Download URL: univer_use-0.1.1a5.tar.gz
  • Upload date:
  • Size: 141.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for univer_use-0.1.1a5.tar.gz
Algorithm Hash digest
SHA256 b84895c1b27a6a420a9cf3b269f204f29beda2d4036071ed4ea8c6e39ad2bea7
MD5 8f4cab5c7232e84268e24db0fcfda92b
BLAKE2b-256 bafbe38cf6a89b5ae2652c2bf6f82953eaf33a33ebe38c35829d6e5835535a1d

See more details on using hashes here.

Provenance

The following attestation bundles were made for univer_use-0.1.1a5.tar.gz:

Publisher: release.yml on dream-num/univer-use

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

File details

Details for the file univer_use-0.1.1a5-py3-none-any.whl.

File metadata

  • Download URL: univer_use-0.1.1a5-py3-none-any.whl
  • Upload date:
  • Size: 20.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for univer_use-0.1.1a5-py3-none-any.whl
Algorithm Hash digest
SHA256 dad4b53feff0ddbc1c022e553253d4895c0f94078b404e8ac7a0edea01354e05
MD5 5a1e066ae3d8287490b53c489cc012d6
BLAKE2b-256 04fb370192d99066a3cf227f2fd8cb21865b212599371840be4ffff04c3a4ed8

See more details on using hashes here.

Provenance

The following attestation bundles were made for univer_use-0.1.1a5-py3-none-any.whl:

Publisher: release.yml on dream-num/univer-use

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