Skip to main content

Perfect tables from pandas dataframes.

Project description

greater_tables Project

Greater Tables

Greater Tables is a Python tool for producing high-quality, static display tables—intended for use in journal articles, books, formal reports, and printed financial statements. It turns your pandas DataFrame into a clean, black-and-white table—ready for print, PDF, or web. It produces consistent, typographically sound output in HTML, LaTeX (via TikZ), and plain text.

It’s opinionated but flexible, with many options and sensible defaults. Designed for use in Jupyter Lab, Quarto, and scripting environments, it auto-detects the output format and renders accordingly. Display tables are small and focused—the end result of your analysis, after selecting rows and columns, ordering, and labeling. Greater Tables helps you get those raw materials onto the page, cleanly and consistently.

from greater_tables import GT
GT(df)

Or use display(GT(df)) in notebooks and Quarto documents. Once created, a GT(df) object is immutable; re-create it to apply new options. Arguments can be passed directly or loaded from a YAML config file—validated using pydantic.

Greater Tables offers similar functionality to pandas.DataFrame.to_html, to_latex, and to_markdown, but with tighter control, better defaults, and no reliance on pandas internals. The LaTeX backend uses TikZ for precise control over layout and grid lines.

This is a tool for serious tables—no sparklines, colors, or shading. Just your data, rendered cleanly.

Also included: Fabricator, a flexible test DataFrame generator—specify row count, index and column hierarchies, data types, missing values, and more.

Installation

pip install greater-tables

Documentation

ReadtheDocs.

Source

GitHub.

Licence

MIT.

Examples

import pandas as pd
import numpy as np
from greater_tables import sGT
level_1 = ["Group A", "Group A", "Group B", "Group B", 'Group C']
level_2 = ['Sub 1', 'Sub 2', 'Sub 2', 'Sub 3', 'Sub 3']

multi_index = pd.MultiIndex.from_arrays([level_1, level_2])
start = pd.Timestamp.today().normalize()  
end = pd.Timestamp(f"{start.year}-12-31")  # End of the year
df = pd.DataFrame(
{'year': np.arange(2020, 2025, dtype=int), 
'a': np.array((100, 105, 2000, 2025, 100000), dtype=int),
'b': 10. ** np.linspace(-9, 9, 5),
'c': np.linspace(601, 4000, 5),
'd': pd.date_range(start=start, end=end, periods=5),
'e': 'once upon a time, risk is hard to define, not in Kansas anymore, neutrinos are hard to detect,  $\\int_\\infty^\\infty e^{-x^2/2}dx$ is a hard integral'.split(',')
}).set_index('year')
df.columns = multi_index
gtc.GT(df, caption='A simple GT table.', 
       year_cols='year',
       vrule_widths=(1,.5, 0))

The output illustrates:

  • Quarto or Jupyter automatically calls the class's _repr_html_ method (or _repr_latex_ for pdf/TeX/Beamer output), providing seamless integration across different output formats. print() produces fixed-pitch text output.
  • Text is left-aligned, numbers are right-aligned, and dates are centered.
  • The index is displayed, and formatted without a comma separator, being specified in year_cols. Columns specified in ratio_col use % formatting. Explicit control provided over all columns; these are just helpers.
  • The first column of integers with a comma thousands separator and no decimals.
  • The second column of floats spans several orders of magnitude and is formatted using Engineering format, n for nano through k for kilo.
  • The third column of floats is formatted with a comma separator and two decimals, based on the average absolute value.
  • The fourth column of date times is formatted as ISO standard dates.
  • Text, in the last column, is sensibly wrapped and can include TeX.
  • The vertical lines separate the levels of the column multiindex.

The Name

Obviously, the name is a play on the great_tables package. I have been maintaining a set of macros called GREATools (generalized, reusable, extensible actuarial tools) in VBA and Python since the late 1990s, and call all my macro packages GREAT.

📁 Project Layout

greater_tables_project/
|   LICENSE
|   pyproject.toml
|   README.md
|   
+---dist
|       
+---docs
|   |   books.bib
|   |   conf.py
|   |   greater_tables.data.rst
|   |   greater_tables.rst
|   |   index.rst
|   |   library.bib
|   |   make.bat
|   |   Makefile
|   |   modules.rst
|   |   start-server.bat
|   |   style.csl
|   |   
+---greater_tables
|   |   __init__.py
|   |   cli.py
|   |   gtconfig.py
|   |   gtcore.py
|   |   gtenums.py
|   |   gtformats.py
|   |   hasher.py
|   |   testdf.py
|   |   tex_svg.py
|   |   
|   +---data
|   |   |   __init__.py
|   |   |   tex_list.csv
|   |   |   tex_list.py
|   |   |   words-12.md
|           
+---greater_tables.egg-info
|       
+---img
|       hard-html.png
|       hard-tex.png

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

greater_tables-5.2.1.tar.gz (1.3 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

greater_tables-5.2.1-py3-none-any.whl (472.3 kB view details)

Uploaded Python 3

File details

Details for the file greater_tables-5.2.1.tar.gz.

File metadata

  • Download URL: greater_tables-5.2.1.tar.gz
  • Upload date:
  • Size: 1.3 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for greater_tables-5.2.1.tar.gz
Algorithm Hash digest
SHA256 8e6381eee2d9b7d2fc25e0436c6f5bb9ce564eb81a7e99458181ef70d6f4e3a4
MD5 432d34d361c23919c6ee0323087cffa7
BLAKE2b-256 0ef4421f0751cdd91f3ddd5c78262dc878aed668aadec8a07fac994386c1b75a

See more details on using hashes here.

File details

Details for the file greater_tables-5.2.1-py3-none-any.whl.

File metadata

  • Download URL: greater_tables-5.2.1-py3-none-any.whl
  • Upload date:
  • Size: 472.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.3

File hashes

Hashes for greater_tables-5.2.1-py3-none-any.whl
Algorithm Hash digest
SHA256 7825a7dc6d94e2175c99a6b83cb6b21baa6349705adcd8d2422029c836b63aef
MD5 068f410c05a21822f7ee20711c2947f8
BLAKE2b-256 62b8242c7585913e430be1e2f740e67d1c61bb5ba271f5022613aa804a12ca0d

See more details on using hashes here.

Supported by

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