With apologies, development of this library has ceased except for bug fixes or behavioral issues. Pull requests for other changes are unlikely to be merged.
| Help | |
|---|---|
| Versions 6.x.x → | Documentation |
| Versions 7.x.x → | Documentation |
| Changelog | |
| Issues | |
| Contributions and Thanks | |
- Smoothly display and modify tabular data
- Edit cells directly
- Cell values can potentially be any class, the default is any class with a
__str__method - Drag and drop columns and rows
- Editable Treeview mode with working drag and drop, undo, etc.
- Multiple line header and index cells
- Expand row heights and column widths
- Change fonts and font size (not for individual cells)
- Change any colors in the sheet
- Dropdown boxes
- Check boxes
- Progress bars
- Hide rows and/or columns
- Left
"w", Center"center"or Right"e"text alignment for any cell/row/column - In-built natural sorting
- Optional built-in find window
Note that due to the limitations of the Tkinter Canvas right-to-left (RTL) languages are not supported.
"""
Versions 7+ have succinct and easy to read syntax:
"""
# set data
sheet["A1"].data = "edited cell A1"
# get data
column_b = sheet["B"].data
# add 2 empty columns and add the change to undo stack
sheet.insert_columns(columns=2, idx=4, undo=True)
# delete columns 0 and 3 and add the change to undo stack
sheet.delete_columns(columns=[0, 3], undo=True)- ALL
extra_bindings()event objects have changed, information here. - The bound function for
extra_bindings()with"edit_cell"/"end_edit_cell"no longer requires a return value and no longer sets the cell to the return value. Use this instead. edit_cell_validationhas been removed and replaced with the functionedit_validation(), information here.- Only Python versions >=
3.8are supported. tksheetfile names have been changed.- Many other smaller changes, see the changelog for more information.




