Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cokelaer/reports
Utilities to ease the creation of HTML/PDF reports using Python language
https://github.com/cokelaer/reports
Last synced: about 2 months ago
JSON representation
Utilities to ease the creation of HTML/PDF reports using Python language
- Host: GitHub
- URL: https://github.com/cokelaer/reports
- Owner: cokelaer
- License: bsd-3-clause
- Created: 2016-03-04T13:04:22.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2021-09-09T08:04:40.000Z (over 3 years ago)
- Last Synced: 2024-11-01T09:33:38.717Z (2 months ago)
- Language: JavaScript
- Size: 188 KB
- Stars: 10
- Watchers: 2
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.rst
- License: LICENSE
Awesome Lists containing this project
README
REPORTS
=========.. image:: https://badge.fury.io/py/reports.svg
:target: https://pypi.python.org/pypi/reports.. image:: https://travis-ci.org/cokelaer/reports.svg?branch=master
:target: https://travis-ci.org/cokelaer/reports.. image:: https://coveralls.io/repos/github/cokelaer/reports/badge.svg?branch=master
:target: https://coveralls.io/github/cokelaer/reports?branch=master.. image:: http://readthedocs.org/projects/reports/badge/?version=latest
:target: http://reports.readthedocs.org/en/latest/?badge=latest
:alt: Documentation Status:Python version: Python 3.7, 3.8, 3.9
:Online documentation: `On readthedocs `_
:Issues and bug reports: `On github `_Reports is a Python package that provides tools to create HTML
documents. It is based on a set of JINJA templates and a class called
**Report**. In addition tools such as HTMLTable can help in the creation of HTML
table to be included in the report.The package relies on Pandas for the HTML table creation, as shown in the
example below.We provide a simple JINJA example (stored with the pacakge in
./share/data/templates/generic directory) and we let the users design their own
templates.This is used in `GDSCTools `_.
Warnings
========Reports is maintained but no new future will be added. It is maintained for the
GDSCTools project but if you find it useful please feel free to use it.Installation
============::
pip install reports
Usage
======Example
----------------
Here below, we show the code used to create this `example <_static/report/index.html>`_.::
# We will create a Report and insert an HTML table in it
from reports import Report, HTMLTable# Let us create some data. It will be a HTML table built using Pandas
# but you could create the HTML table code yourself.
import pandas as pd# create a dataframe to play with. Note that there is a numeric column
# In addition, there is a column (Entry name) that will be transformed into URLs
df = pd.DataFrame({
"Entry name":["ZAP70_HUMAN", "TBK1_HUMAN"],
"Entry": ["P43403", "Q9UHD2"],
"Frequency": [0.5,0.9]})# From reports, we convert the dataframe into a HTMLTable
table = HTMLTable(df)# a numeric column can be colorized
table.add_bgcolor('Frequency', cmap="copper")# part of URLs can be added to the content of a column
table.add_href('Entry', url='http://uniprot.org/uniprot/', suffix="")
html = table.to_html()# Create a generic report. It has a set of tags that can be filled
# using the **jinja** attribute.
r = Report("generic")# set the **summary** tag with the HTML code of the table
r.jinja['summary'] = html# Generate and show the report
r.create_report(onweb=True)See the results in `example <_static/report/index.html>`_
Using your own JINJA template
-------------------------------------Create a directory called **test** and add a file called **index.html**
Add this code::
{{ title }}
Number of reads : {{ reads }}
Now, create your HTML files::
from reports import Report
report = Report("test")
report.jinja['title'] = 'Simple Example'
report.jinja['reads'] = "123456"
report.create_report(onweb=True)Issues
===========Please fill bug report in https://github.com/cokelaer/reports