Skip to main content

Create self-contained HTML reports from Python.

Project description

Report Creator

License PyPI Version Python Versions Python Stats

Library to assemble reports in HTML from various components using python

Features

  • Good pandas/dataframe/table support
  • Look modern
  • Allows markdown as input for text blocks
  • Allows html as input
  • Components for things like metrics ("Accuracy: 87%") from a key & value
  • Support for plotting figures, interactive plotly and matplotlib
  • images (styled by the library) with an option to fetch at report build time (no fetch on render)
  • json/yaml/python/java code blocks with color syntax highlighting
  • Support tab containers (not printer friendly)
  • Add support for any Jupyter widget, any object that renders in a notebook should render to a report
  • Add built-in easy plotting that looks stylistically consistent with the report
  • Add option to change the report icon based on a github account avatar, or an image
  • Add a metric type for timeseries data which should some aggregate function of the data, and plot over time.
  • Add diagram component with Mermaid JS
  • Write documentation!
  • Add a status metric that supports up to a handful of k/v pairs (k=task, v=status)
  • Add bookmark anchors to blocks
  • Add Footer to report
  • Add log file block (https://github.com/jwodder/apachelogs) with analytics
  • Add Radar chart
  • Add choropleth map plot type (maybe?)
  • Youtube embeds rc.Video(url: str, label: str)
  • File attachments (downloadable dataset from page)

Example

import report_creator as rc

with rc.ReportCreator(
    title="My Report",
    description="My Report Description",
    footer="My Report Footer",
) 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

conda create --name rc python=3.12
conda activate rc
pip install -r requirements.txt -U

# recommended installs for code hygiene
pip install ruff

# build "kitchen_sink" example
make

# install local package
pip install -e .

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

Publish

  • run publish.sh

Dev Notes

  • 4/18/24 - no breaking changes, all changes should go through standard deprecation policies
  • To render math you'll need to pip install md4mathjax

Docs

pip install sphinx sphinx-autodoc-typehints sphinx-book-theme sphinx_copybutton sphinxcontrib-mermaid --upgrade

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.0.28.tar.gz (23.3 kB view details)

Uploaded Source

Built Distribution

report_creator-1.0.28-py3-none-any.whl (21.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: report_creator-1.0.28.tar.gz
  • Upload date:
  • Size: 23.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.7

File hashes

Hashes for report_creator-1.0.28.tar.gz
Algorithm Hash digest
SHA256 8f9a12c7386f92983cd690b3f55d544b4dae09fcd9830b6fc6ac1da50e109ced
MD5 cc883c7188026e30bb382ea3802369bc
BLAKE2b-256 34099068ad751057084c23edb6397063fe76587ace82fa2f8ffd1786f8e5cc3d

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for report_creator-1.0.28-py3-none-any.whl
Algorithm Hash digest
SHA256 1935139b40a6162d79a074be767bd801ace10cc178d679ae0db58269454806de
MD5 085af487e14cf1d3ae95294ff5cd6e90
BLAKE2b-256 a9f1f71210aa57a030988381f33da6a81d82335a047f7fc02a1fe01bb9168088

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page