DataTable¶
A widget to display text in a table. This includes the ability to update data, use a cursor to navigate data, respond to mouse clicks, delete rows or columns, and individually render each cell as a Rich Text renderable. DataTable provides an efficiently displayed and updated table capable for most applications.
Applications may have custom rules for formatting, numbers, repopulating tables after searching or filtering, and responding to selections. The widget emits events to interface with custom logic.
- Focusable
- Container
Guide¶
Adding data¶
The following example shows how to fill a table with data.
First, we use add_columns to include the lane
, swimmer
, country
, and time
columns in the table.
After that, we use the add_rows method to insert the rows into the table.
from textual.app import App, ComposeResult
from textual.widgets import DataTable
ROWS = [
("lane", "swimmer", "country", "time"),
(4, "Joseph Schooling", "Singapore", 50.39),
(2, "Michael Phelps", "United States", 51.14),
(5, "Chad le Clos", "South Africa", 51.14),
(6, "László Cseh", "Hungary", 51.14),
(3, "Li Zhuhao", "China", 51.26),
(8, "Mehdy Metella", "France", 51.58),
(7, "Tom Shields", "United States", 51.73),
(1, "Aleksandr Sadovnikov", "Russia", 51.84),
(10, "Darren Burns", "Scotland", 51.84),
]
class TableApp(App):
def compose(self) -> ComposeResult:
yield DataTable()
def on_mount(self) -> None:
table = self.query_one(DataTable)
table.add_columns(*ROWS[0])
table.add_rows(ROWS[1:])
app = TableApp()
if __name__ == "__main__":
app.run()
To add a single row or column use add_row and add_column, respectively.
Styling and justifying cells¶
Cells can contain more than just plain strings - Rich renderables such as Text
are also supported.
Text
objects provide an easy way to style and justify cell content:
from rich.text import Text
from textual.app import App, ComposeResult
from textual.widgets import DataTable
ROWS = [
("lane", "swimmer", "country", "time"),
(4, "Joseph Schooling", "Singapore", 50.39),
(2, "Michael Phelps", "United States", 51.14),
(5, "Chad le Clos", "South Africa", 51.14),
(6, "László Cseh", "Hungary", 51.14),
(3, "Li Zhuhao", "China", 51.26),
(8, "Mehdy Metella", "France", 51.58),
(7, "Tom Shields", "United States", 51.73),
(1, "Aleksandr Sadovnikov", "Russia", 51.84),
(10, "Darren Burns", "Scotland", 51.84),
]
class TableApp(App):
def compose(self) -> ComposeResult:
yield DataTable()
def on_mount(self) -> None:
table = self.query_one(DataTable)
table.add_columns(*ROWS[0])
for row in ROWS[1:]:
# Adding styled and justified `Text` objects instead of plain strings.
styled_row = [
Text(str(cell), style="italic #03AC13", justify="right") for cell in row
]
table.add_row(*styled_row)
app = TableApp()
if __name__ == "__main__":
app.run()
Keys¶
When adding a row to the table, you can supply a key to add_row.
A key is a unique identifier for that row.
If you don't supply a key, Textual will generate one for you and return it from add_row
.
This key can later be used to reference the row, regardless of its current position in the table.
When working with data from a database, for example, you may wish to set the row key
to the primary key of the data to ensure uniqueness.
The method add_column also accepts a key
argument and works similarly.
Keys are important because cells in a data table can change location due to factors like row deletion and sorting. Thus, using keys instead of coordinates allows us to refer to data without worrying about its current location in the table.
If you want to change the table based solely on coordinates, you may need to convert that coordinate to a cell key first using the coordinate_to_cell_key method.
Cursors¶
A cursor allows navigating within a table with the keyboard or mouse. There are four cursor types: "cell"
(the default), "row"
, "column"
, and "none"
.
Change the cursor type by assigning to
the cursor_type
reactive attribute.
The coordinate of the cursor is exposed via the cursor_coordinate
reactive attribute.
Using the keyboard, arrow keys, Page Up, Page Down, Home and End move the cursor highlight, emitting a CellHighlighted
message, then enter selects the cell, emitting a CellSelected
message. If the
cursor_type
is row, then RowHighlighted
and RowSelected
are emitted, similarly for ColumnHighlighted
and ColumnSelected
.
When moving the mouse over the table, a MouseMove
event is emitted, the cell hovered over is styled,
and the hover_coordinate
reactive attribute is updated. Clicking the mouse
then emits the CellHighlighted
and CellSelected
events.
A new table starts with no cell highlighted, i.e., row and column are zero. You can force the first item to highlight with move_cursor(row=1, column=1)
. All row and column indexes start at one.
from itertools import cycle
from textual.app import App, ComposeResult
from textual.widgets import DataTable
ROWS = [
("lane", "swimmer", "country", "time"),
(4, "Joseph Schooling", "Singapore", 50.39),
(2, "Michael Phelps", "United States", 51.14),
(5, "Chad le Clos", "South Africa", 51.14),
(6, "László Cseh", "Hungary", 51.14),
(3, "Li Zhuhao", "China", 51.26),
(8, "Mehdy Metella", "France", 51.58),
(7, "Tom Shields", "United States", 51.73),
(1, "Aleksandr Sadovnikov", "Russia", 51.84),
(10, "Darren Burns", "Scotland", 51.84),
]
cursors = cycle(["column", "row", "cell", "none"])
class TableApp(App):
def compose(self) -> ComposeResult:
yield DataTable()
def on_mount(self) -> None:
table = self.query_one(DataTable)
table.cursor_type = next(cursors)
table.zebra_stripes = True
table.add_columns(*ROWS[0])
table.add_rows(ROWS[1:])
def key_c(self):
table = self.query_one(DataTable)
table.cursor_type = next(cursors)
app = TableApp()
if __name__ == "__main__":
app.run()
Updating data¶
Cells can be updated using the update_cell and update_cell_at methods.
Removing data¶
To remove all data in the table, use the clear method.
To remove individual rows, use remove_row.
The remove_row
method accepts a key
argument, which identifies the row to be removed.
If you wish to remove the row below the cursor in the DataTable
, use coordinate_to_cell_key
to get the row key of
the row under the current cursor_coordinate
, then supply this key to remove_row
:
# Get the keys for the row and column under the cursor.
row_key, _ = table.coordinate_to_cell_key(table.cursor_coordinate)
# Supply the row key to `remove_row` to delete the row.
table.remove_row(row_key)
Removing columns¶
To remove individual columns, use remove_column.
The remove_column
method accepts a key
argument, which identifies the column to be removed.
You can remove the column below the cursor using the same coordinate_to_cell_key
method described above:
# Get the keys for the row and column under the cursor.
_, column_key = table.coordinate_to_cell_key(table.cursor_coordinate)
# Supply the column key to `column_row` to delete the column.
table.remove_column(column_key)
Fixed data¶
You can fix a number of rows and columns in place, keeping them pinned to the top and left of the table respectively.
To do this, assign an integer to the fixed_rows
or fixed_columns
reactive attributes of the DataTable
.
from textual.app import App, ComposeResult
from textual.widgets import DataTable
class TableApp(App):
CSS = "DataTable {height: 1fr}"
def compose(self) -> ComposeResult:
yield DataTable()
def on_mount(self) -> None:
table = self.query_one(DataTable)
table.focus()
table.add_columns("A", "B", "C")
for number in range(1, 100):
table.add_row(str(number), str(number * 2), str(number * 3))
table.fixed_rows = 2
table.fixed_columns = 1
table.cursor_type = "row"
table.zebra_stripes = True
app = TableApp()
if __name__ == "__main__":
app.run()
In the example above, we set fixed_rows
to 2
, and fixed_columns
to 1
,
meaning the first two rows and the leftmost column do not scroll - they always remain
visible as you scroll through the data table.
Sorting¶
The DataTable rows can be sorted using the sort
method.
There are three methods of using sort
:
- By Column. Pass columns in as parameters to sort by the natural order of one or more columns. Specify a column using either a
ColumnKey
instance or thekey
you supplied toadd_column
. For example,sort("country", "region")
would sort by country, and, when the country values are equal, by region. - By Key function. Pass a function as the
key
parameter to sort, similar to the key function parameter of Python'ssorted
built-in. The function will be called once per row with a tuple of all row values. - By both Column and Key function. You can specify which columns to include as parameters to your key function. For example,
sort("hours", "rate", key=lambda h, r: h*r)
passes two values to the key function for each row.
The reverse
argument reverses the order of your sort. Note that correct sorting may require your key function to undo your formatting.
from rich.text import Text
from textual.app import App, ComposeResult
from textual.widgets import DataTable, Footer
ROWS = [
("lane", "swimmer", "country", "time 1", "time 2"),
(4, "Joseph Schooling", Text("Singapore", style="italic"), 50.39, 51.84),
(2, "Michael Phelps", Text("United States", style="italic"), 50.39, 51.84),
(5, "Chad le Clos", Text("South Africa", style="italic"), 51.14, 51.73),
(6, "László Cseh", Text("Hungary", style="italic"), 51.14, 51.58),
(3, "Li Zhuhao", Text("China", style="italic"), 51.26, 51.26),
(8, "Mehdy Metella", Text("France", style="italic"), 51.58, 52.15),
(7, "Tom Shields", Text("United States", style="italic"), 51.73, 51.12),
(1, "Aleksandr Sadovnikov", Text("Russia", style="italic"), 51.84, 50.85),
(10, "Darren Burns", Text("Scotland", style="italic"), 51.84, 51.55),
]
class TableApp(App):
BINDINGS = [
("a", "sort_by_average_time", "Sort By Average Time"),
("n", "sort_by_last_name", "Sort By Last Name"),
("c", "sort_by_country", "Sort By Country"),
("d", "sort_by_columns", "Sort By Columns (Only)"),
]
current_sorts: set = set()
def compose(self) -> ComposeResult:
yield DataTable()
yield Footer()
def on_mount(self) -> None:
table = self.query_one(DataTable)
for col in ROWS[0]:
table.add_column(col, key=col)
table.add_rows(ROWS[1:])
def sort_reverse(self, sort_type: str):
"""Determine if `sort_type` is ascending or descending."""
reverse = sort_type in self.current_sorts
if reverse:
self.current_sorts.remove(sort_type)
else:
self.current_sorts.add(sort_type)
return reverse
def action_sort_by_average_time(self) -> None:
"""Sort DataTable by average of times (via a function) and
passing of column data through positional arguments."""
def sort_by_average_time_then_last_name(row_data):
name, *scores = row_data
return (sum(scores) / len(scores), name.split()[-1])
table = self.query_one(DataTable)
table.sort(
"swimmer",
"time 1",
"time 2",
key=sort_by_average_time_then_last_name,
reverse=self.sort_reverse("time"),
)
def action_sort_by_last_name(self) -> None:
"""Sort DataTable by last name of swimmer (via a lambda)."""
table = self.query_one(DataTable)
table.sort(
"swimmer",
key=lambda swimmer: swimmer.split()[-1],
reverse=self.sort_reverse("swimmer"),
)
def action_sort_by_country(self) -> None:
"""Sort DataTable by country which is a `Rich.Text` object."""
table = self.query_one(DataTable)
table.sort(
"country",
key=lambda country: country.plain,
reverse=self.sort_reverse("country"),
)
def action_sort_by_columns(self) -> None:
"""Sort DataTable without a key."""
table = self.query_one(DataTable)
table.sort("swimmer", "lane", reverse=self.sort_reverse("columns"))
app = TableApp()
if __name__ == "__main__":
app.run()
Labeled rows¶
A "label" can be attached to a row using the add_row method. This will add an extra column to the left of the table which the cursor cannot interact with. This column is similar to the leftmost column in a spreadsheet containing the row numbers. The example below shows how to attach simple numbered labels to rows.
from rich.text import Text
from textual.app import App, ComposeResult
from textual.widgets import DataTable
ROWS = [
("lane", "swimmer", "country", "time"),
(4, "Joseph Schooling", "Singapore", 50.39),
(2, "Michael Phelps", "United States", 51.14),
(5, "Chad le Clos", "South Africa", 51.14),
(6, "László Cseh", "Hungary", 51.14),
(3, "Li Zhuhao", "China", 51.26),
(8, "Mehdy Metella", "France", 51.58),
(7, "Tom Shields", "United States", 51.73),
(1, "Aleksandr Sadovnikov", "Russia", 51.84),
(10, "Darren Burns", "Scotland", 51.84),
]
class TableApp(App):
def compose(self) -> ComposeResult:
yield DataTable()
def on_mount(self) -> None:
table = self.query_one(DataTable)
table.add_columns(*ROWS[0])
for number, row in enumerate(ROWS[1:], start=1):
label = Text(str(number), style="#B0FC38 italic")
table.add_row(*row, label=label)
app = TableApp()
if __name__ == "__main__":
app.run()
Reactive Attributes¶
Name | Type | Default | Description |
---|---|---|---|
show_header |
bool |
True |
Show the table header |
show_row_labels |
bool |
True |
Show the row labels (if applicable) |
fixed_rows |
int |
0 |
Number of fixed rows (rows which do not scroll) |
fixed_columns |
int |
0 |
Number of fixed columns (columns which do not scroll) |
zebra_stripes |
bool |
False |
Style with alternating colors on rows |
header_height |
int |
1 |
Height of header row |
show_cursor |
bool |
True |
Show the cursor |
cursor_type |
str |
"cell" |
One of "cell" , "row" , "column" , or "none" |
cursor_coordinate |
Coordinate | Coordinate(0, 0) |
The current coordinate of the cursor |
hover_coordinate |
Coordinate | Coordinate(0, 0) |
The coordinate the mouse cursor is above |
Messages¶
- DataTable.CellHighlighted
- DataTable.CellSelected
- DataTable.RowHighlighted
- DataTable.RowSelected
- DataTable.ColumnHighlighted
- DataTable.ColumnSelected
- DataTable.HeaderSelected
- DataTable.RowLabelSelected
Bindings¶
The data table widget defines the following bindings:
Key(s) | Description |
---|---|
enter | Select cells under the cursor. |
up | Move the cursor up. |
down | Move the cursor down. |
right | Move the cursor right. |
left | Move the cursor left. |
pageup | Move one page up. |
pagedown | Move one page down. |
ctrl+home | Move to the top. |
ctrl+end | Move to the bottom. |
home | Move to the home position (leftmost column). |
end | Move to the end position (rightmost column). |
Component Classes¶
The data table widget provides the following component classes:
Class | Description |
---|---|
datatable--cursor |
Target the cursor. |
datatable--hover |
Target the cells under the hover cursor. |
datatable--fixed |
Target fixed columns and fixed rows. |
datatable--fixed-cursor |
Target highlighted and fixed columns or header. |
datatable--header |
Target the header of the data table. |
datatable--header-cursor |
Target cells highlighted by the cursor. |
datatable--header-hover |
Target hovered header or row label cells. |
datatable--even-row |
Target even rows (row indices start at 0) if zebra_stripes. |
datatable--odd-row |
Target odd rows (row indices start at 0) if zebra_stripes. |
Bases: ScrollView
, Generic[CellType]
A tabular widget that contains data.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
bool
|
Whether the table header should be visible or not. |
True
|
|
bool
|
Whether the row labels should be shown or not. |
True
|
|
int
|
The number of rows, counting from the top, that should be fixed and still visible when the user scrolls down. |
0
|
|
int
|
The number of columns, counting from the left, that should be fixed and still visible when the user scrolls right. |
0
|
|
bool
|
Enables or disables a zebra effect applied to the background color of the rows of the table, where alternate colors are styled differently to improve the readability of the table. |
False
|
|
int
|
The height, in number of cells, of the data table header. |
1
|
|
bool
|
Whether the cursor should be visible when navigating the data table or not. |
True
|
|
Literal['renderable', 'css']
|
If the data associated with a cell is an arbitrary renderable with a set foreground color, this determines whether that color is prioritized over the cursor component class or not. |
'css'
|
|
Literal['renderable', 'css']
|
If the data associated with a cell is an arbitrary renderable with a set background color, this determines whether that color is prioritized over the cursor component class or not. |
'renderable'
|
|
CursorType
|
The type of cursor to be used when navigating the data table with the keyboard. |
'cell'
|
|
int
|
The number of cells added on each side of each column. Setting this value to zero will likely make your table very hard to read. |
1
|
|
str | None
|
The name of the widget. |
None
|
|
str | None
|
The ID of the widget in the DOM. |
None
|
|
str | None
|
The CSS classes for the widget. |
None
|
|
bool
|
Whether the widget is disabled or not. |
False
|
BINDINGS
class-attribute
¶
BINDINGS = [
Binding("enter", "select_cursor", "Select", show=False),
Binding("up", "cursor_up", "Cursor up", show=False),
Binding(
"down", "cursor_down", "Cursor down", show=False
),
Binding(
"right", "cursor_right", "Cursor right", show=False
),
Binding(
"left", "cursor_left", "Cursor left", show=False
),
Binding("pageup", "page_up", "Page up", show=False),
Binding(
"pagedown", "page_down", "Page down", show=False
),
Binding("ctrl+home", "scroll_top", "Top", show=False),
Binding(
"ctrl+end", "scroll_bottom", "Bottom", show=False
),
Binding("home", "scroll_home", "Home", show=False),
Binding("end", "scroll_end", "End", show=False),
]
Key(s) | Description |
---|---|
enter | Select cells under the cursor. |
up | Move the cursor up. |
down | Move the cursor down. |
right | Move the cursor right. |
left | Move the cursor left. |
pageup | Move one page up. |
pagedown | Move one page down. |
ctrl+home | Move to the top. |
ctrl+end | Move to the bottom. |
home | Move to the home position (leftmost column). |
end | Move to the end position (rightmost column). |
COMPONENT_CLASSES
class-attribute
¶
COMPONENT_CLASSES = {
"datatable--cursor",
"datatable--hover",
"datatable--fixed",
"datatable--fixed-cursor",
"datatable--header",
"datatable--header-cursor",
"datatable--header-hover",
"datatable--odd-row",
"datatable--even-row",
}
Class | Description |
---|---|
datatable--cursor |
Target the cursor. |
datatable--hover |
Target the cells under the hover cursor. |
datatable--fixed |
Target fixed columns and fixed rows. |
datatable--fixed-cursor |
Target highlighted and fixed columns or header. |
datatable--header |
Target the header of the data table. |
datatable--header-cursor |
Target cells highlighted by the cursor. |
datatable--header-hover |
Target hovered header or row label cells. |
datatable--even-row |
Target even rows (row indices start at 0) if zebra_stripes. |
datatable--odd-row |
Target odd rows (row indices start at 0) if zebra_stripes. |
cell_padding
class-attribute
instance-attribute
¶
cell_padding = cell_padding
Horizontal padding between cells, applied on each side of each cell.
columns
instance-attribute
¶
Metadata about the columns of the table, indexed by their key.
cursor_background_priority
instance-attribute
¶
cursor_background_priority = cursor_background_priority
Should we prioritize the cursor component class CSS background or the renderable background in the event where a cell contains a renderable with a background color.
cursor_column
property
¶
The index of the column that the DataTable cursor is currently on.
cursor_coordinate
class-attribute
instance-attribute
¶
cursor_coordinate = Reactive(
Coordinate(0, 0), repaint=False, always_update=True
)
Current cursor Coordinate
.
This can be set programmatically or changed via the method
move_cursor
.
cursor_foreground_priority
instance-attribute
¶
cursor_foreground_priority = cursor_foreground_priority
Should we prioritize the cursor component class CSS foreground or the renderable foreground in the event where a cell contains a renderable with a foreground color.
cursor_type
class-attribute
instance-attribute
¶
cursor_type = cursor_type
The type of cursor of the DataTable
.
fixed_columns
class-attribute
instance-attribute
¶
fixed_columns = fixed_columns
The number of columns to fix (prevented from scrolling).
fixed_rows
class-attribute
instance-attribute
¶
fixed_rows = fixed_rows
The number of rows to fix (prevented from scrolling).
header_height
class-attribute
instance-attribute
¶
header_height = header_height
The height of the header row (the row of column labels).
hover_column
property
¶
The index of the column that the mouse cursor is currently hovering above.
hover_coordinate
class-attribute
instance-attribute
¶
hover_coordinate = Reactive(
Coordinate(0, 0), repaint=False, always_update=True
)
The coordinate of the DataTable
that is being hovered.
hover_row
property
¶
The index of the row that the mouse cursor is currently hovering above.
ordered_columns
property
¶
The list of Columns in the DataTable, ordered as they appear on screen.
ordered_rows
property
¶
The list of Rows in the DataTable, ordered as they appear on screen.
show_cursor
class-attribute
instance-attribute
¶
show_cursor = show_cursor
Show/hide both the keyboard and hover cursor.
show_header
class-attribute
instance-attribute
¶
show_header = show_header
Show/hide the header row (the row of column labels).
show_row_labels
class-attribute
instance-attribute
¶
show_row_labels = show_row_labels
Show/hide the column containing the labels of rows.
zebra_stripes
class-attribute
instance-attribute
¶
zebra_stripes = zebra_stripes
Apply alternating styles, datatable--even-row and datatable-odd-row, to create a zebra effect, e.g., alternating light and dark backgrounds.
CellHighlighted
¶
Bases: Message
Posted when the cursor moves to highlight a new cell.
This is only relevant when the cursor_type
is "cell"
.
It's also posted when the cell cursor is
re-enabled (by setting show_cursor=True
), and when the cursor type is
changed to "cell"
. Can be handled using on_data_table_cell_highlighted
in
a subclass of DataTable
or in a parent widget in the DOM.
CellSelected
¶
Bases: Message
Posted by the DataTable
widget when a cell is selected.
This is only relevant when the cursor_type
is "cell"
. Can be handled using
on_data_table_cell_selected
in a subclass of DataTable
or in a parent
widget in the DOM.
coordinate
instance-attribute
¶
coordinate = coordinate
The coordinate of the cell that was selected.
ColumnHighlighted
¶
Bases: Message
Posted when a column is highlighted.
This message is only posted when the
cursor_type
is set to "column"
. Can be handled using
on_data_table_column_highlighted
in a subclass of DataTable
or in a parent
widget in the DOM.
cursor_column
instance-attribute
¶
cursor_column = cursor_column
The x-coordinate of the column that was highlighted.
ColumnSelected
¶
Bases: Message
Posted when a column is selected.
This message is only posted when the
cursor_type
is set to "column"
. Can be handled using
on_data_table_column_selected
in a subclass of DataTable
or in a parent
widget in the DOM.
cursor_column
instance-attribute
¶
cursor_column = cursor_column
The x-coordinate of the column that was selected.
RowHighlighted
¶
Bases: Message
Posted when a row is highlighted.
This message is only posted when the
cursor_type
is set to "row"
. Can be handled using
on_data_table_row_highlighted
in a subclass of DataTable
or in a parent
widget in the DOM.
cursor_row
instance-attribute
¶
cursor_row = cursor_row
The y-coordinate of the cursor that highlighted the row.
RowSelected
¶
Bases: Message
Posted when a row is selected.
This message is only posted when the
cursor_type
is set to "row"
. Can be handled using
on_data_table_row_selected
in a subclass of DataTable
or in a parent
widget in the DOM.
cursor_row
instance-attribute
¶
cursor_row = cursor_row
The y-coordinate of the cursor that made the selection.
add_column
¶
Add a column to the table.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
TextType
|
A str or Text object containing the label (shown top of column). |
required |
|
int | None
|
Width of the column in cells or None to fit content. |
None
|
|
str | None
|
A key which uniquely identifies this column. If None, it will be generated for you. |
None
|
|
CellType | None
|
The value to insert into pre-existing rows. |
None
|
Returns:
Type | Description |
---|---|
ColumnKey
|
Uniquely identifies this column. Can be used to retrieve this column regardless of its current location in the DataTable (it could have moved after being added due to sorting/insertion/deletion of other columns). |
add_row
¶
Add a row at the bottom of the DataTable.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
CellType
|
Positional arguments should contain cell data. |
()
|
|
int | None
|
The height of a row (in lines). Use |
1
|
|
str | None
|
A key which uniquely identifies this row. If None, it will be generated for you and returned. |
None
|
|
TextType | None
|
The label for the row. Will be displayed to the left if supplied. |
None
|
Returns:
Type | Description |
---|---|
RowKey
|
Unique identifier for this row. Can be used to retrieve this row regardless of its current location in the DataTable (it could have moved after being added due to sorting or insertion/deletion of other rows). |
add_rows
¶
add_rows(rows)
Add a number of rows at the bottom of the DataTable.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Iterable[Iterable[CellType]]
|
Iterable of rows. A row is an iterable of cells. |
required |
Returns:
Type | Description |
---|---|
list[RowKey]
|
A list of the keys for the rows that were added. See
the |
coordinate_to_cell_key
¶
coordinate_to_cell_key(coordinate)
Return the key for the cell currently occupying this coordinate.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Coordinate
|
The coordinate to exam the current cell key of. |
required |
Returns:
Type | Description |
---|---|
CellKey
|
The key of the cell currently occupying this coordinate. |
Raises:
Type | Description |
---|---|
CellDoesNotExist
|
If the coordinate is not valid. |
get_cell
¶
get_cell(row_key, column_key)
Given a row key and column key, return the value of the corresponding cell.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The row key of the cell. |
required |
|
ColumnKey | str
|
The column key of the cell. |
required |
Returns:
Type | Description |
---|---|
CellType
|
The value of the cell identified by the row and column keys. |
get_cell_at
¶
get_cell_at(coordinate)
Get the value from the cell occupying the given coordinate.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Coordinate
|
The coordinate to retrieve the value from. |
required |
Returns:
Type | Description |
---|---|
CellType
|
The value of the cell at the coordinate. |
Raises:
Type | Description |
---|---|
CellDoesNotExist
|
If there is no cell with the given coordinate. |
get_cell_coordinate
¶
get_cell_coordinate(row_key, column_key)
Given a row key and column key, return the corresponding cell coordinate.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The row key of the cell. |
required |
|
ColumnKey | str
|
The column key of the cell. |
required |
Returns:
Type | Description |
---|---|
Coordinate
|
The current coordinate of the cell identified by the row and column keys. |
Raises:
Type | Description |
---|---|
CellDoesNotExist
|
If the specified cell does not exist. |
get_column
¶
get_column(column_key)
Get the values from the column identified by the given column key.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
ColumnKey | str
|
The key of the column. |
required |
Returns:
Type | Description |
---|---|
Iterable[CellType]
|
A generator which yields the cells in the column. |
Raises:
Type | Description |
---|---|
ColumnDoesNotExist
|
If there is no column corresponding to the key. |
get_column_at
¶
get_column_at(column_index)
Get the values from the column at a given index.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
int
|
The index of the column. |
required |
Returns:
Type | Description |
---|---|
Iterable[CellType]
|
A generator which yields the cells in the column. |
Raises:
Type | Description |
---|---|
ColumnDoesNotExist
|
If there is no column with the given index. |
get_column_index
¶
get_column_index(column_key)
Return the current index for the column identified by column_key.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
ColumnKey | str
|
The column key to find the current index of. |
required |
Returns:
Type | Description |
---|---|
int
|
The current index of the specified column key. |
Raises:
Type | Description |
---|---|
ColumnDoesNotExist
|
If the column key does not exist. |
get_row
¶
get_row(row_key)
Get the values from the row identified by the given row key.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The key of the row. |
required |
Returns:
Type | Description |
---|---|
list[CellType]
|
A list of the values contained within the row. |
Raises:
Type | Description |
---|---|
RowDoesNotExist
|
When there is no row corresponding to the key. |
get_row_at
¶
get_row_at(row_index)
Get the values from the cells in a row at a given index. This will return the values from a row based on the rows current position in the table.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
int
|
The index of the row. |
required |
Returns:
Type | Description |
---|---|
list[CellType]
|
A list of the values contained in the row. |
Raises:
Type | Description |
---|---|
RowDoesNotExist
|
If there is no row with the given index. |
get_row_index
¶
get_row_index(row_key)
Return the current index for the row identified by row_key.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The row key to find the current index of. |
required |
Returns:
Type | Description |
---|---|
int
|
The current index of the specified row key. |
Raises:
Type | Description |
---|---|
RowDoesNotExist
|
If the row key does not exist. |
is_valid_column_index
¶
is_valid_column_index(column_index)
is_valid_coordinate
¶
is_valid_coordinate(coordinate)
Return a boolean indicating whether the given coordinate is valid.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Coordinate
|
The coordinate to validate. |
required |
Returns:
Type | Description |
---|---|
bool
|
True if the coordinate is within the bounds of the table. |
move_cursor
¶
Move the cursor to the given position.
Example
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
int | None
|
The new row to move the cursor to. |
None
|
|
int | None
|
The new column to move the cursor to. |
None
|
|
bool
|
Whether to animate the change of coordinates. |
False
|
|
bool
|
Scroll the cursor into view after moving. |
True
|
refresh_column
¶
refresh_column(column_index)
refresh_coordinate
¶
refresh_coordinate(coordinate)
Refresh the cell at a coordinate.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Coordinate
|
The coordinate to refresh. |
required |
Returns:
Type | Description |
---|---|
Self
|
The |
remove_column
¶
remove_column(column_key)
Remove a column (identified by a key) from the DataTable.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
ColumnKey | str
|
The key identifying the column to remove. |
required |
Raises:
Type | Description |
---|---|
ColumnDoesNotExist
|
If the column key does not exist. |
remove_row
¶
remove_row(row_key)
Remove a row (identified by a key) from the DataTable.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The key identifying the row to remove. |
required |
Raises:
Type | Description |
---|---|
RowDoesNotExist
|
If the row key does not exist. |
sort
¶
Sort the rows in the DataTable
by one or more column keys or a
key function (or other callable). If both columns and a key function
are specified, only data from those columns will sent to the key function.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
ColumnKey | str
|
One or more columns to sort by the values in. |
()
|
|
Callable[[Any], Any] | None
|
A function (or other callable) that returns a key to use for sorting purposes. |
None
|
|
bool
|
If True, the sort order will be reversed. |
False
|
Returns:
Type | Description |
---|---|
Self
|
The |
update_cell
¶
update_cell(
row_key, column_key, value, *, update_width=False
)
Update the cell identified by the specified row key and column key.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
RowKey | str
|
The key identifying the row. |
required |
|
ColumnKey | str
|
The key identifying the column. |
required |
|
CellType
|
The new value to put inside the cell. |
required |
|
bool
|
Whether to resize the column width to accommodate for the new cell content. |
False
|
Raises:
Type | Description |
---|---|
CellDoesNotExist
|
When the supplied |
update_cell_at
¶
update_cell_at(coordinate, value, *, update_width=False)
Update the content inside the cell currently occupying the given coordinate.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
Coordinate
|
The coordinate to update the cell at. |
required |
|
CellType
|
The new value to place inside the cell. |
required |
|
bool
|
Whether to resize the column width to accommodate for the new cell content. |
False
|
textual.widgets.data_table
¶
CursorType
module-attribute
¶
The valid types of cursors for DataTable.cursor_type
.
CellDoesNotExist
¶
Bases: Exception
The cell key/index was invalid.
Raised when the coordinates or cell key provided does not exist in the DataTable (e.g. out of bounds index, invalid key)
CellKey
¶
Bases: NamedTuple
A unique identifier for a cell in the DataTable.
A cell key is a (row_key, column_key)
tuple.
Even if the cell changes visual location (i.e. moves to a different coordinate in the table), this key can still be used to retrieve it, regardless of where it currently is.
Column
dataclass
¶
Metadata for a column in the DataTable.
get_render_width
¶
get_render_width(data_table)
Width, in cells, required to render the column with padding included.
Parameters:
Name | Type | Description | Default |
---|---|---|---|
|
DataTable[Any]
|
The data table where the column will be rendered. |
required |
Returns:
Type | Description |
---|---|
int
|
The width, in cells, required to render the column with padding included. |
ColumnDoesNotExist
¶
Bases: Exception
Raised when the column index or column key provided does not exist in the DataTable (e.g. out of bounds index, invalid key)
ColumnKey
¶
Bases: StringKey
Uniquely identifies a column in the DataTable.
Even if the visual location of the column changes due to sorting or other modifications, a key will always refer to the same column.
DuplicateKey
¶
Bases: Exception
The key supplied already exists.
Raised when the RowKey or ColumnKey provided already refers to an existing row or column in the DataTable. Keys must be unique.
Row
dataclass
¶
Metadata for a row in the DataTable.
RowDoesNotExist
¶
Bases: Exception
Raised when the row index or row key provided does not exist in the DataTable (e.g. out of bounds index, invalid key)
RowKey
¶
Bases: StringKey
Uniquely identifies a row in the DataTable.
Even if the visual location of the row changes due to sorting or other modifications, a key will always refer to the same row.
StringKey
¶
An object used as a key in a mapping.
It can optionally wrap a string, and lookups into a map using the object behave the same as lookups using the string itself.