Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jieter/django-tables2
django-tables2 - An app for creating HTML tables
https://github.com/jieter/django-tables2
django python sorting tables tableview
Last synced: 5 days ago
JSON representation
django-tables2 - An app for creating HTML tables
- Host: GitHub
- URL: https://github.com/jieter/django-tables2
- Owner: jieter
- License: other
- Created: 2010-12-07T05:26:16.000Z (about 14 years ago)
- Default Branch: master
- Last Pushed: 2025-01-02T07:49:26.000Z (24 days ago)
- Last Synced: 2025-01-19T17:48:43.636Z (6 days ago)
- Topics: django, python, sorting, tables, tableview
- Language: Python
- Homepage: https://django-tables2.readthedocs.io/en/latest/
- Size: 3.71 MB
- Stars: 1,930
- Watchers: 51
- Forks: 428
- Open Issues: 95
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-starred - django-tables2 - django-tables2 - An app for creating HTML tables (Python)
- -awesome-django - django-tables2 - HTML tables with pagination/sorting. (Third-Party Packages / General)
- awesome-django - django-tables2 - HTML tables with pagination/sorting. (Third-Party Packages / General)
- best-of-web-python - GitHub - 13% open · ⏱️ 15.04.2024): (Django Utilities)
README
# django-tables2 - An app for creating HTML tables
[![Latest PyPI version](https://badge.fury.io/py/django-tables2.svg)](https://pypi.python.org/pypi/django-tables2)
[![Any color you like](https://img.shields.io/badge/code%20style-black-000000.svg)](https://github.com/ambv/black)django-tables2 simplifies the task of turning sets of data into HTML tables. It
has native support for pagination and sorting. It does for HTML tables what
`django.forms` does for HTML forms. e.g.- Available on pypi as [django-tables2](https://pypi.python.org/pypi/django-tables2)
- Tested against currently supported versions of Django
[and supported python 3 versions Django supports](https://docs.djangoproject.com/en/dev/faq/install/#what-python-version-can-i-use-with-django).
- [Documentation on readthedocs.org](https://django-tables2.readthedocs.io/en/latest/)
- [Bug tracker](http://github.com/jieter/django-tables2/issues)Features:
- Any iterable can be a data-source, but special support for Django `QuerySets` is included.
- The builtin UI does not rely on JavaScript.
- Support for automatic table generation based on a Django model.
- Supports custom column functionality via subclassing.
- Pagination.
- Column based table sorting.
- Template tag to enable trivial rendering to HTML.
- Generic view mixin.![An example table rendered using django-tables2](https://cdn.rawgit.com/jieter/django-tables2/master/docs/img/example.png)
![An example table rendered using django-tables2 and bootstrap theme](https://cdn.rawgit.com/jieter/django-tables2/master/docs/img/bootstrap.png)
![An example table rendered using django-tables2 and semantic-ui theme](
https://cdn.rawgit.com/jieter/django-tables2/master/docs/img/semantic.png)## Example
Start by adding `django_tables2` to your `INSTALLED_APPS` setting like this:
```python
INSTALLED_APPS = (
...,
"django_tables2",
)
```Creating a table for a model `Simple` is as simple as:
```python
import django_tables2 as tablesclass SimpleTable(tables.Table):
class Meta:
model = Simple
```
This would then be used in a view:```python
class TableView(tables.SingleTableView):
table_class = SimpleTable
queryset = Simple.objects.all()
template_name = "simple_list.html"
```
And finally in the template:```
{% load django_tables2 %}
{% render_table table %}
```This example shows one of the simplest cases, but django-tables2 can do a lot more!
Check out the [documentation](https://django-tables2.readthedocs.io/en/latest/) for more details.