Skip to main content

reportgen is a Python library for creating and updating analysis report.

Project description

Release v0.1.8

reportgen is a Python library for creating and updating analysis report.

Release History

0.1.8(2018-03-28)

  • Add subpackages metrics and preprocessing which contain entropy銆乄OE銆乨iscretization etc..

  • Add associate analysis(FP growth): frequent_itemsets and association_rules.

  • Add functions :ClassifierReport,type_of_var.

  • Fix the logic of package.

  • Fix some bugs.

0.1.6(2017-12-06)

  • Add function rpt.plot().

  • Support drawing on the exist matplotlib figure and Report file

  • Fix some bugs.

0.1.5(2017-11-29)

  • Add function AnalysisReport, it can plot the general data to pptx files.

  • Fix some bugs.

0.1.0(2017-11-18)

  • Create.

Feature Support

reportgen has the following capabilities, with many more on the roadmap:

  • get all the texts in the pptx file

  • get all the images in the pptx file

  • add one slide simply about charts/tables/images with pandas in a pptx file

  • add slides simply about charts/tables/images with pandas in a pptx file

Quick Start

  1. Get texts or images in a pptx file.

# import
import reportgen as rpt
# Open a pptx file
p=rpt.Report('analysis.pptx')
# We can get the texts and images simply.
result=p.get_texts()
print('\n'.join(result))
# All the images will saved in folder '.\\images\\'.
p.get_images()
  1. Created a analysis report.

#
import reportgen as rpt
      import pandas as pd
      # Open a pptx file
      p=rpt.Report('template.pptx')# The parameters can be defaulted
      # add a cover
      p.add_cover(title='A analysis report powered by reportgen')
      # add a chart slide
      data=pd.DataFrame({'Jack':[90,80,100],'David':[100,70,85]},index=['Math','English','Physics'])
      p.add_slide(data={'data':data,'slide_type':'chart','type':'COLUMN_CLUSTERED'},\
      title='the scores report',summary='Our class got excellent results',footnote='This is a footnote.')
# add a table slide
      data=pd.DataFrame({'Jack':[90,80,100],'David':[100,70,85]},index=['Math','English','Physics'])
      p.add_slide(data={'data':data,'slide_type':'table'},title='the scores report',summary='Our class got excellent results',footnote='This is a footnote.')
      # add a textbox slide
      data='This a paragraph. \n'*4
      p.add_slide(data={'data':data,'slide_type':'textbox'},title='This is a textbox slide',summary='',footnote='')
      # add a picture slide
      data='.\\images\\images.png'
      p.add_slide(data={'data':data,'slide_type':'picture'},title='This is a picture slide')
p.save('analysis report.pptx')

In general, I divide a slide of analysis report into four parts: title銆乻ummary銆乫ootnote and the body data. And the body are one or more charts/textboxs/tables/pictures.

The add_slide which is the most commonly used function has the following parameters:

add_slide(data=[{'data':,'slide_type':,'type':},],title='',summary='',footnote='',layouts='auto')

For example, we can draw a chart on the left side, and insert a picture on the right.

import reportgen as rpt
import pandas as pd
p=rpt.Report()
scores=pd.DataFrame({'Jack':[90,80,100],'David':[100,70,85]},index=['Math','English','Physics'])
data=[{'data':scores,'slide_type':'chart','type':'COLUMN_CLUSTERED'},\
{'data':'.\\images2.jpg','slide_type':'picture'}]
p.add_slide(data=data)
p.save('add_slide.pptx')

As a lazy person, I also provide a solution with less scripts.

import reportgen as rpt
p=rpt.Report()
imgs=['.\\images\\'+img for img in os.listdir('.\\images\\')]
p.add_slides(data=imgs)
# more functions way
slides_data=[{'title':'ppt{}'.format(i),'data':data} for i in range(10)]
p.add.slides(slides_data)
p.save('add_slides.pptx')

Now you can get a glance at any data.

import pandas as pd
import reportgen as rpt

data=pd.read_excel('Scores.xlsx')
rpt.AnalysisReport(data,filename='Analysis Report of Scores.pptx');

The scripts will make a pptx file which analysis all the fields of the data in a visual way.

TO DO

  • support export analysis report to html

  • make the chart_type recommend more intelligence

Contact

If you have any question,you can email to gasongjian AT 126.com. And if you have a WeChat account,you can focus to my WeChat Official Account: gasongjian.

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

reportgen-0.1.8.tar.gz (2.4 MB view details)

Uploaded Source

Built Distribution

reportgen-0.1.8-py2.py3-none-any.whl (2.5 MB view details)

Uploaded Python 2 Python 3

File details

Details for the file reportgen-0.1.8.tar.gz.

File metadata

  • Download URL: reportgen-0.1.8.tar.gz
  • Upload date:
  • Size: 2.4 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for reportgen-0.1.8.tar.gz
Algorithm Hash digest
SHA256 1a80cecd96c598288863622462863b5d704d703478b373a6e72efd29f6b8e9dd
MD5 79bcbfa04ef3b83db35cf039b786f2f6
BLAKE2b-256 3149e22fdd40bd526d615fe72bb2011029eeb166619f00eeca1be2254423d163

See more details on using hashes here.

File details

Details for the file reportgen-0.1.8-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for reportgen-0.1.8-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 e42266be135836ceade8d7b73589871e62c7e373aed31879771fc04375b8ed1a
MD5 14189e5e816437ab8ac88bc735ea75bd
BLAKE2b-256 d24f5d75cb342d386de79c8443003bc730071b68259a1aff087d4ead1b802537

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