Skip to main content

Generates Office documents (PPTX/XLSX) from template files that are flexibly populated or composed using provided context.

Project description

Office Templates

Office Templates is a Python library turns PowerPoint (PPTX) and Excel (XLSX) files into reusable templates. Placeholders inside those templates are resolved using provided context so that you can generate templated documents without hard‑coding content.

Installation

Install using uv:

uv add office-templates

For Excel support, install with the xlsx extra:

uv add office-templates[xlsx]

Key Features

  • PowerPoint and Excel rendering – supply a PPTX or XLSX file and a context dictionary to produce a finished document.
  • Placeholder expressions using {{ }} to access attributes, call methods, filter lists and perform math.
  • Formatting helpers for dates, numbers and string casing (upper, lower, title).
  • Arithmetic operators in expressions (+, -, *, /).
  • Dynamic table and worksheet expansion when a placeholder resolves to a list.
  • Chart support where spreadsheet values inside charts contain placeholders.
  • Permission enforcement – data is filtered based on check_permissions function.
  • Global context injection for values that should always be available.
  • Context extraction to inspect templates and determine which context keys are required.
  • Image placeholders – shapes or cells starting with %imagesqueeze% or %image% are replaced by an image downloaded from the provided URL.
  • Node/edge graph generation – programmatically create graph visualizations with positioned nodes and connecting edges on PPTX slides.

Codebase Overview

office_templates/ contains the library:

  • office_renderer/ – logic for rendering PPTX and XLSX files. This handles text boxes, tables, charts, worksheets and the %image%/%imagesqueeze% directives.
  • templating/ – the template engine responsible for parsing and evaluating expressions.
  • tests/ – the test suite.

Start by looking at the functions in office_renderer to see how a file is rendered. The templating package is standalone and can be read independently if you want to learn how placeholders are parsed.

Writing Templates

Template files are just normal PowerPoint or Excel documents. No coding or macros are required—just type plain text placeholders where you want dynamic information to appear.

  1. Design your layout. Build the slides or workbook exactly as you would for a static report.
  2. Insert placeholders. Anywhere you would type text you can instead type a placeholder wrapped in {{ and }}:
    • {{ user.name }} – insert a simple value from the context.
    • {{ user.profile__email }} – read nested attributes using . or __.
    • {{ users[is_active=True].email }} – pick a specific item from a list.
    • {{ amount * 1.15 }} – perform calculations.
    • {{ price | .2f }} or {{ name | upper }} – apply formatting filters.
  3. Repeat rows or slides for lists. If a placeholder by itself resolves to a list, extra rows (or slides) will be created so that each item appears separately. This is how you build tables from querysets.
  4. Add images. To include an image from a URL, create a text box or cell that starts with %image% or %imagesqueeze% followed by the address: %image% https://example.com/logo.png %imagesqueeze% https://example.com/logo.png The former keeps the image's aspect ratio while fitting it inside the shape. The latter squeezes the image to exactly fill the shape.
  5. Save the file and register it in the Django admin as a report template.

You can experiment with the example files in office_templates/raw_templates to see common patterns. Remember that all placeholders are plain text—avoid formulas or punctuation that might confuse the parser.

Chart data sheets can also contain placeholders so your graphs update automatically.

Composing Presentations

Creating Presentations Without Templates

The compose_pptx function can create presentations without any template files by using PowerPoint's default layouts:

from office_templates.office_renderer import compose_pptx

slide_specs = [
    {
        "layout": "Title Slide",
        "placeholders": ["My Presentation", "No template needed"],
    },
    {
        "layout": "Title and Content",
        "placeholders": ["Content Slide", "Uses default layouts"],
    },
]

result, errors = compose_pptx(
    template_files=None,  # or [] - both work!
    slide_specs=slide_specs,
    global_context={},
    output="output.pptx",
)

Available default layouts include:

  • Title Slide
  • Title and Content
  • Section Header
  • Two Content
  • Comparison
  • Title Only
  • Blank
  • Content with Caption
  • Picture with Caption
  • And more...

Creating Node/Edge Graphs

The library can programmatically generate node/edge graph visualizations in PowerPoint presentations using the compose_pptx function. This is useful for creating architecture diagrams, flowcharts, network topologies, and organizational charts.

Basic Usage

Graph slides are specified just like any other slide in compose_pptx, by including a graph key in the slide specification:

from office_templates.office_renderer import compose_pptx

slide_specs = [
    {
        "layout": "graph",  # Use a layout designed for graphs
        "graph": {
            "nodes": [
                {
                    "id": "frontend",
                    "name": "Frontend",
                    "detail": "React.js Application",
                    "position": {"x": 1, "y": 2},
                },
                {
                    "id": "backend",
                    "name": "Backend API",
                    "detail": "Node.js Server",
                    "position": {"x": 4, "y": 2},
                },
                {
                    "id": "database",
                    "name": "Database",
                    "detail": "PostgreSQL",
                    "position": {"x": 7, "y": 2},
                },
            ],
            "edges": [
                {"from": "frontend", "to": "backend", "label": "HTTPS"},
                {"from": "backend", "to": "database", "label": "SQL"},
            ],
        }
    }
]

result, errors = compose_pptx(
    template_files=["template.pptx"],
    slide_specs=slide_specs,
    global_context={},
    output="output.pptx",
    use_tagged_layouts=True,
)

Graph Structure

Each graph dictionary should contain:

  • nodes (list, required): List of node dictionaries with:

    • id (string, required): Unique identifier for the node
    • name (string, required): Display name shown in the node shape
    • detail (string, optional): Additional details shown below the name in smaller font
    • position (dict, required): Position on the slide with x and y keys (in inches)
    • parent (string, optional): ID of parent node for nesting (placeholder functionality)
  • edges (list, required): List of edge dictionaries with:

    • from (string, required): Source node ID
    • to (string, required): Target node ID
    • label (string, optional): Text label for the edge

Features

  • Automatic slide expansion: Slides automatically resize to fit all nodes
  • Elbow connectors: Edges use right-angle connectors for professional appearance
  • Template variables: Node names, details, and edge labels support {{ }} placeholders
  • Multiple graphs: Create multiple graph slides in the same presentation by including multiple slide specs with graph keys
  • Template layouts: Use % layout graph % in template slides to define custom layouts
  • Mix with regular slides: Graph slides can be intermixed with regular content slides

Node Positioning

Node positions are specified in inches from the top-left corner of the slide:

"position": {"x": 3.5, "y": 2.0}  # 3.5 inches right, 2 inches down

Nodes are automatically sized to fit their content, and slides expand to accommodate all nodes plus margins.

Multiple Graphs

You can create multiple graph slides in a single presentation:

slide_specs = [
    {
        "layout": "title",
        "placeholders": ["Architecture Overview", "System Design"],
    },
    {
        "layout": "graph",
        "graph": {
            "nodes": [...],  # Development environment
            "edges": [...],
        }
    },
    {
        "layout": "graph",
        "graph": {
            "nodes": [...],  # Production environment
            "edges": [...],
        }
    },
]

Learning More

After trying the example templates in raw_templates/ explore the tests/ directory to see many usage patterns. The test files demonstrate complex placeholders, permission checks and the new image replacement behaviour.

Development

Use uv sync --all-extras to set up the python environment.

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

office_templates-0.5.3.tar.gz (82.2 kB view details)

Uploaded Source

Built Distribution

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

office_templates-0.5.3-py3-none-any.whl (49.0 kB view details)

Uploaded Python 3

File details

Details for the file office_templates-0.5.3.tar.gz.

File metadata

  • Download URL: office_templates-0.5.3.tar.gz
  • Upload date:
  • Size: 82.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for office_templates-0.5.3.tar.gz
Algorithm Hash digest
SHA256 4a96d0e73251eee921de67655ca92dafaad77e673488b74cb8a405621c344d31
MD5 05efbb7dd91258e30f0445aac2b400e9
BLAKE2b-256 8ca3158f7af62b280a208651414855c3eeb0c7a746173ef72a55b564fc2227e4

See more details on using hashes here.

Provenance

The following attestation bundles were made for office_templates-0.5.3.tar.gz:

Publisher: publish.yml on gaussian/python-office-templates

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

File details

Details for the file office_templates-0.5.3-py3-none-any.whl.

File metadata

File hashes

Hashes for office_templates-0.5.3-py3-none-any.whl
Algorithm Hash digest
SHA256 517e53de1374f43990445b476a1740010b2388a6ea18ff0e4b23946d8f3ce62e
MD5 cd08b14021341adb312fe008f1e7914b
BLAKE2b-256 854a0a150cc7460aab511c71ec30569fa1f308e4c1bb8ef0aa037b5ff5fc8e35

See more details on using hashes here.

Provenance

The following attestation bundles were made for office_templates-0.5.3-py3-none-any.whl:

Publisher: publish.yml on gaussian/python-office-templates

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