Shiny for Python bindings for Tabulator JS
- Filtering
- Grouping
- Editing
- Input validation
- History with undo and redo actions
- Pagination
- Layout
- Column formatters
- Column calculations
- Multi column headers
- Packaged themes
- Spreadsheets supporting multiple sheets
- Download data
- Freeze data
To learn more about pytabulator, see the documentation at https://eoda-dev.github.io/py-tabulator/.
Bindings for R are available at https://github.com/eoda-dev/rtabulator.
You can install the released version of pytabulator from PyPI with:
pip install pytabulator
You can install the development version of pytabulator like so:
pip install git+https://github.com/eoda-dev/py-tabulator
import pandas as pd
from pytabulator import TableOptions, render_data_frame
from shiny import render
from shiny.express import input, ui
ui.div("Click on row to print name", style="padding: 10px;")
@render.code
async def txt():
print(input.tabulator_row_clicked())
return input.tabulator_row_clicked()["Name"]
@render_data_frame(table_options=TableOptions(height=500))
def tabulator():
return pd.read_csv(
"https://raw.githubusercontent.com/datasciencedojo/datasets/master/titanic.csv"
)
# uvicorn docs.examples.getting_started.shiny_core_basic:app
import pandas as pd
from pytabulator import TableOptions, Tabulator, output_tabulator, render_tabulator
from shiny import App, render, ui
app_ui = ui.page_fluid(
ui.output_text_verbatim("txt", placeholder=True),
output_tabulator("tabulator"),
)
def server(input, output, session):
@render_tabulator
def tabulator():
df = pd.read_csv(
"https://raw.githubusercontent.com/datasciencedojo/datasets/master/titanic.csv"
)
return Tabulator(df, table_options=TableOptions(height=311))
@render.code
async def txt():
print(input.tabulator_row_clicked())
return str(input.tabulator_row_clicked())
app = App(app_ui, server)
Run detailed example:
shiny run docs/examples/getting_started/shiny_express_all.py
poetry install
poetry run pytest
npm install
npm run prettier
npm run build