Skip to content

Good Practice Tables - an XlsxWriter wrapper to write consistently formatted statistical tables to Excel.

License

Notifications You must be signed in to change notification settings

best-practice-and-impact/gptables

Repository files navigation

Good Practice Tables (gptables)

Actions build status Documentation Status PyPI release

gptables is an opinionated python package for spreadsheet production. It produces .xlsx files from your pandas dataframes or using reticulate in R. You define the mapping from your data to elements of the table. It does the rest.

gptables uses the official guidance on good practice spreadsheets. It advocates a strong adherence to the guidance by restricting the range of operations possible. The default theme gptheme should accommodate most use cases. However, the Theme object allows development of custom themes, where other formatting is required.

gptables is developed and maintained by the Analysis Function. It can be installed from PyPI or GitHub. The source code is maintained on GitHub. Users may also be interested in a11ytables, an R native equivalent to gptables, and csvcubed, a package for turning data and metadata into machine-readable CSV-W files.

5 Simple Steps

  1. You map your data to the elements of a GPTable.
  2. You can define the format of each element with a custom Theme, or simply use the default - gptheme.
  3. Optionally design a Cover page to provide information that relates to all of the tables in your Workbook.
  4. Optionally upload a notes_table with information about any notes.
  5. You write_workbook to win.

Note: This package is not intending to create perfectly accessible spreadsheets but will help with the bulk of the work needed. Users of this packages should refer back to the main spreadsheet guidance or the spreadsheet accessibility checklist after using it to make sure nothing has been missed. Please email Analysis.Function@ons.gov.uk if you use the package so we can monitor use and the outputs produced.