Create self-contained HTML reports from Python.
Project description
Report Creator
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), andMetriccomponents. - Interactive Plotting: Full support for
Plotlyfigures with a custom "RC" theme for professional-looking charts by default. - Matplotlib & Seaborn: Automatic detection and rendering of
MatplotlibandSeabornobjects, with consistent styling using a context manager. - Specialized Charts: Built-in components for
Radarcharts,Bar,Line,Pie,Scatter,Box, andHistogram. - Advanced Metrics:
MetricandMetricGroupfor KPI displays, includingEventMetricfor time-series frequency analysis.
Content & Layout
- Rich Layout System: Flexible report structuring using
rc.Block()(vertical) andrc.Group()(horizontal) stacks. - Modern UI Components: Interactive elements like
Accordion/Collapsesections andSelecttabbed interfaces. - Superior Markdown: Full GitHub Flavored Markdown (GFM) support, including Emojis, Math (LaTeX), and RST directives.
- Diagrams as Code: Native
Mermaid.jssupport 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, andJson. - SQL Prettifier: Heuristic formatting for SQL queries to improve readability in reports.
- Smart Media Handling: Images 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
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
- Report bugs via GitHub Issues.
Contributors
Star History
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file report_creator-1.2.1.tar.gz.
File metadata
- Download URL: report_creator-1.2.1.tar.gz
- Upload date:
- Size: 73.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
3e978ee0358b731de53b0901619a2a2dcb06d9196ad9557d381467374fb8cd10
|
|
| MD5 |
9636c89d5501d1289adf3b1930477b70
|
|
| BLAKE2b-256 |
bcd627cacf0d1c37f98221b2d10342fa00de7ac03cd701b6065df5b058a6bb2c
|
File details
Details for the file report_creator-1.2.1-py3-none-any.whl.
File metadata
- Download URL: report_creator-1.2.1-py3-none-any.whl
- Upload date:
- Size: 61.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.12
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5b7bd64293dc502d361f63cbb5fe58dc1ff2451651c92ab7ddc19c2d95958d6c
|
|
| MD5 |
75ffb485cefe634a5741fb66470eccf9
|
|
| BLAKE2b-256 |
ddb198e34137cc7626eb9986bb876d83fdff995afb7793d1ac45c8282aafde90
|