Skip to main content

Generates reports (PPTX) from template files that are flexibly populated using the Django ORM, without hard-coding.

Project description

Django Template Reports

Django Template Reports is a Django application that turns PowerPoint (PPTX) and Excel (XLSX) files into reusable templates. Placeholders inside those templates are resolved using your Django models so that you can generate polished reports without hard‑coding the layout.

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.
  • Admin integration with a flow to choose a template, configure context and generate ReportRun records. Generated files can be downloaded individually or as a ZIP archive.
  • Configurable filenames using config.filename_template in ReportDefinition.
  • 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.

Codebase Overview

template_reports/ contains the library:

  • models/ – base classes ReportDefinition and ReportRun plus utilities for file storage.
  • admin/ – Django admin classes and views used to generate reports and download them in bulk.
  • 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.
  • templates/ and raw_templates/ – the admin templates and example Office templates.
  • tests/ – the test suite.

Start by looking at ReportDefinition in models/base.py and 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 template_reports/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.

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.

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

django_template_reports-0.5.1.tar.gz (13.6 kB view details)

Uploaded Source

Built Distribution

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

django_template_reports-0.5.1-py3-none-any.whl (18.1 kB view details)

Uploaded Python 3

File details

Details for the file django_template_reports-0.5.1.tar.gz.

File metadata

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

File hashes

Hashes for django_template_reports-0.5.1.tar.gz
Algorithm Hash digest
SHA256 d2687fb20833222d5d0da043b5eede316b1689b0db4a6c37aebac6a54b12bb6e
MD5 1d1752e42d7f9f716e3cb6954a04cd66
BLAKE2b-256 5fbd7480c3afa6005ee57bb0dd6b6f1695041da36e21075781cf1b2d80c0b1e5

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_template_reports-0.5.1.tar.gz:

Publisher: publish.yml on gaussian/django-template-reports

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

File details

Details for the file django_template_reports-0.5.1-py3-none-any.whl.

File metadata

File hashes

Hashes for django_template_reports-0.5.1-py3-none-any.whl
Algorithm Hash digest
SHA256 a4fd8501881f668680a1aec563c39518f77c1bcb51c3279222adaa73c4ec90bc
MD5 d969eb4d4b2410934200a0bbf711a7e6
BLAKE2b-256 275984ccc0fbe7402e868e9f5c9881526b42c044e8a559cb419a2587495e6e32

See more details on using hashes here.

Provenance

The following attestation bundles were made for django_template_reports-0.5.1-py3-none-any.whl:

Publisher: publish.yml on gaussian/django-template-reports

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