A Python library for rendering structured tables as high-quality images or HTML.
Project description
Table Renderer 📊
English | 繁體中文
table-renderer is a powerful and lightweight Python library designed to convert structured tables into high-quality images (PNG, JPG, WebP) or HTML. By combining the layout power of CSS with an intuitive Python API, it's perfect for automated reporting, Kubernetes CronJobs, or any data visualization task.
✨ Features
- Broad Compatibility: Fully supports Python 3.12, 3.13, and 3.14.
- Business Friendly: Uses
pypdfium2(Apache-2.0) andWeasyPrintfor a 100% MIT-compatible dependency chain. - High-Quality Rendering: Powered by WeasyPrint (CSS engine), supporting complex text wrapping, alignment, and cell merging.
- Auto-Crop: Automatically crops images to the actual table area using visual detection, eliminating unnecessary white space.
- Object-Oriented API: Clean
Table->Row/Column->Cellhierarchy with fluent interface support. - Cascading Styles: Manage visual styles effortlessly with "Global Defaults + Local Overrides."
- Multi-language Font Support: Support for font stacks (e.g., different fonts for English and Chinese).
- Customizable Resolution: Adjustable DPI for high-resolution output (e.g., 300 DPI for print).
- Lightweight Deployment: No heavy browser dependencies (like Chromium), making it ideal for Docker/K8s.
🖼 Visual Example
Here is an example table generated using the code in the Quick Start section:
🚀 Quick Start
Installation
If you are developing within this project, use uv:
uv sync
To install it in another project:
pip install .
Basic Usage
from table_renderer import Table
# 1. Initialize a 3x3 table
table = Table(3, 3)
table.set_width(600)
table.set_border(1, "black", "solid")
# 2. Set header style (Row 0)
header = table.get_row(0)
header.set_background("#333").set_font(color="white", weight="bold", size=16)
header.set_align(horizontal="center")
table.cell(0, 0).set_text("Product")
table.cell(0, 1).set_text("Category")
table.cell(0, 2).set_text("Price")
# 3. Add content and demonstrate merging
table.cell(1, 0).set_text("MacBook Pro").span(rows=1, cols=2)
table.cell(1, 2).set_text("$2,000")
table.cell(2, 0).set_text("Magic Mouse")
table.cell(2, 1).set_text("Peripherals")
table.cell(2, 2).set_text("$79")
# 4. Global column styling (align prices to the right)
table.get_column(2).set_align(horizontal="right").set_width(100)
# 5. Export to image with custom DPI and padding
table.to_image("report.png", dpi=300, padding=20)
🛠 Advanced Features
1. Cell Merging
Use the anchor-based design to merge cells by specifying the starting cell and the span.
# Merge first row, first two columns (1 row, 2 columns)
table.cell(0, 0).span(rows=1, cols=2).set_text("Merged Header")
2. Font Management
Load local font files and define font stacks for character-level fallback.
# Load local font files (.ttf / .otf)
table.add_font("./fonts/Roboto-Regular.ttf")
table.add_font("./fonts/NotoSansTC-Medium.otf")
# Define a font stack: English prefers Roboto, Chinese falls back to Noto Sans
table.set_font(family="Roboto-Regular, NotoSansTC-Medium")
3. Embedding Images in Cells
You can easily embed local images into any cell.
# Set an image with optional width/height constraints
table.cell(1, 0).set_image("path/to/logo.png", width=50)
table.cell(1, 0).set_text("Company Logo") # Text appears below the image
4. Layout & Sizing
Mix fixed widths, percentages, and auto-sizing.
table.set_width(800) # Total table width
table.get_column(0).set_width(200) # Fixed 200px
table.get_column(1).set_width("auto") # Distribute remaining space
5. DPI, Formats & Padding
Fine-tune your output image quality and margins.
# High-res JPG with custom 20px padding
table.to_image("output.jpg", dpi=300, padding=20)
# Lightweight WebP with tight margins
table.to_image("output.webp", dpi=72, padding=0)
🐳 Docker / Kubernetes Deployment
Since weasyprint relies on system-level C libraries, your Dockerfile should include these dependencies:
FROM python:3.12-slim
# Install system dependencies for WeasyPrint rendering and fonts
RUN apt-get update && apt-get install -y --no-install-recommends \
libpango-1.0-0 \
libharfbuzz0b \
libpangoft2-1.0-0 \
libpangocairo-1.0-0 \
fonts-noto-cjk \
&& rm -rf /var/lib/apt/lists/*
WORKDIR /app
COPY . .
RUN pip install .
CMD ["python", "main.py"]
🧪 Development
Running Tests
We use pytest for testing. Ensure you have installed the development dependencies.
uv run pytest --cov=src/table_renderer tests/
Linting & Formatting
We use ruff to maintain code quality.
uv run ruff check .
uv run ruff format .
🤝 Contributing
Contributions are welcome! If you find a bug or have a feature request, please open an issue or submit a pull request.
- Fork the Project
- Create your Feature Branch (
git checkout -b feature/AmazingFeature) - Commit your Changes (
git commit -m 'Add some AmazingFeature') - Push to the Branch (
git push origin feature/AmazingFeature) - Open a Pull Request
📜 License
Distributed under the MIT License. See LICENSE for more information.
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 table_renderer-0.1.0.tar.gz.
File metadata
- Download URL: table_renderer-0.1.0.tar.gz
- Upload date:
- Size: 9.7 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03b129b8657eccdd6315cc89d991b822c184526352e1d70aa48f3b11b8ce5bdc
|
|
| MD5 |
68b2b5d5cf18ba8a273b51ab865a2bdc
|
|
| BLAKE2b-256 |
b2e6f32c2f2bc1ed9439f53a264de351ba27c2d84f45fa8b9982a7ee5d2723df
|
File details
Details for the file table_renderer-0.1.0-py3-none-any.whl.
File metadata
- Download URL: table_renderer-0.1.0-py3-none-any.whl
- Upload date:
- Size: 12.6 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.19 {"installer":{"name":"uv","version":"0.11.19","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
03a5d69bc6c29efccdf1289b88fe4e0852573e0b5ff285efb010fc8053468d15
|
|
| MD5 |
382e8482266966c7a1fe97f7c3b43c07
|
|
| BLAKE2b-256 |
384496eae993c54dc3bc44b11737070fba6eb95a136dd59ab959dd4970c449f1
|