Skip to main content

Create self-contained HTML reports from Python.

Project description

Report Creator

License PyPI Version Python Versions

GitHub | PyPI | Documentation | Issues | Getting Started

Library to assemble reports in HTML from various components using python. This is not meant to be a replacement for do-it-yourself HTML, it's a tool to put together professional looking reports from python easily and quickly. The philosophy for layout is that components flow in either the horizontal (rc.Group()) or Vertical (rc.Block()) direction.

Talk to this repo using DeepWiki Report Creator

Use the documentation in Cursor, Windsurf, Claude Desktop or another MCP Client via the Context7 MCP for example

Create an html report on this dataframe, use context7

Features

Data & Visualization

  • Deep Pandas Integration: Native support for DataFrames in Table, DataTable (searcheable/sortable), and Metric components.
  • Interactive Plotting: Full support for Plotly figures with a custom "RC" theme for professional-looking charts by default.
  • Matplotlib & Seaborn: Automatic detection and rendering of Matplotlib and Seaborn objects, with consistent styling using a context manager.
  • Specialized Charts: Built-in components for Radar charts, Bar, Line, Pie, Scatter, Box, and Histogram.
  • Advanced Metrics: Metric and MetricGroup for KPI displays, including EventMetric for time-series frequency analysis.

Content & Layout

  • Rich Layout System: Flexible report structuring using rc.Block() (vertical) and rc.Group() (horizontal) stacks.
  • Modern UI Components: Interactive elements like Accordion/Collapse sections and Select tabbed interfaces.
  • Superior Markdown: Full GitHub Flavored Markdown (GFM) support, including Emojis, Math (LaTeX), and RST directives.
  • Diagrams as Code: Native Mermaid.js support for flowcharts, sequence diagrams, and more, with built-in pan and zoom.

Technical Capabilities

  • Syntax Highlighting: Code blocks with support for multiple languages including Sql, Python, Yaml, and Json.
  • SQL Prettifier: Heuristic formatting for SQL queries to improve readability in reports.
  • Smart Media Handling: Images and Galleries can be local, remote (fetched at build time), or Base64 encoded, with automatic styling.
  • Self-Contained Output: Generates standalone HTML files that bundle only the required JavaScript dependencies (Plotly, DataTables, etc.).
  • Deterministic Styling: Automatic, repeatable color generation for headings and labels to ensure visual consistency.

Example

import report_creator as rc

with rc.ReportCreator(
    title="My Report",
    description="My Report Description",
    footer="My Report Footer",
    accent_color="red"
) as report:
    view = rc.Block(
        rc.Text(
            """It was the best of times, it was the worst of times, it was the age of wisdom, it was the age of foolishness, it was the epoch of belief, it was the epoch of incredulity, it was the season of light, it was the season of darkness, it was the spring of hope, it was the winter of despair.""",
            label="Charles Dickens, A Tale of Two Cities",
        ),
        rc.Group(
            rc.Metric(
                heading="Answer to Life, The Universe, and Everything",
                value="42",
            ),
            rc.Metric(
                heading="Author",
                value="Douglas Adams",
            ),
        ),
        rc.Bar(
            px.data.medals_long(),
            x="nation",
            y="count",
            dimension="medal",
            label="Bar Chart - Olympic Medals",
        ),
        rc.Scatter(
            px.data.iris(),
            x="sepal_width",
            y="sepal_length",
            dimension="species",
            marginal="histogram",
            label="Scatter Plot - Iris",
        ),
    )

    report.save(view, "report.html")

Development

This project has been configured for Claude Clode. These are entirely optional to use for development.

conda create -n rc -c conda-forge python=3.13
conda activate rc
make setup

# recommended for code hygiene
make format

# install as a local package:
python3 -m pip install -e .

# see dependency tree:
pipdeptree --exclude pip,pipdeptree,setuptools,wheel,twine

# build examples:
make examples

# build a *specific* example:
make examples EXAMPLES=examples/myreport.py

# run tests
make tests

# build doc
make doc

# release new version
make release

# show list of make targets
make targets

Get in touch

This project is under active development

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

report_creator-1.2.2.tar.gz (78.3 kB view details)

Uploaded Source

Built Distribution

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

report_creator-1.2.2-py3-none-any.whl (64.1 kB view details)

Uploaded Python 3

File details

Details for the file report_creator-1.2.2.tar.gz.

File metadata

  • Download URL: report_creator-1.2.2.tar.gz
  • Upload date:
  • Size: 78.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for report_creator-1.2.2.tar.gz
Algorithm Hash digest
SHA256 3efe805e749df3ea9812c757c8d41f1ece3bdf62d8ba39a288e90b3f55752a9f
MD5 87715ec0e16de5100a18686bd1cab380
BLAKE2b-256 bda54498f80e2e019c1c6761c1b54d22464ea8789b97921fef0bb340d2e67512

See more details on using hashes here.

File details

Details for the file report_creator-1.2.2-py3-none-any.whl.

File metadata

  • Download URL: report_creator-1.2.2-py3-none-any.whl
  • Upload date:
  • Size: 64.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.12.12

File hashes

Hashes for report_creator-1.2.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f17bd8472a888deef80eb699345557fe5709a9ae21538d2de1b5308c3a2ebe19
MD5 85cb2550cf81bed20ec698b9161adc93
BLAKE2b-256 a866d16390e803dde20bc31169b98fb9a44f8397f64e50e581ca87cdc8797180

See more details on using hashes here.

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