PySide6 QTableWidget Example

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
# The QTableWidget class provides an 
# item-based table view with a default model.
#
# Simply put, it's a table.

from random import randint
import sys

from PySide6.QtCore import Qt
from PySide6.QtWidgets import (QApplication,
    QWidget, QVBoxLayout, QTableWidget,
    QTableWidgetItem, QHeaderView, QLabel)


class Window(QWidget):
    
    def __init__(self):

        super().__init__()
        
        layout = QVBoxLayout()
        self.setLayout(layout)
        
        # 1 - Create the table widget passing row and column
        #     count to the constructor.
        #     This table widget has three rows and four columns
        self.table_widget = QTableWidget(3, 4)
        
        # Fit columns to table width
        self.table_widget.horizontalHeader().setSectionResizeMode(
            QHeaderView.ResizeMode.Stretch)

        # 2 - Use QTableWidgetItem instances 
        #     to manipulate table cells
        # Fill the cells with some data
        for r in range(self.table_widget.rowCount()):
            for c in range(self.table_widget.columnCount()):
                item = QTableWidgetItem(str(randint(0, 100)))
                item.setTextAlignment(Qt.AlignmentFlag.AlignCenter)
                self.table_widget.setItem(r, c, item)
                
        self.table_widget.currentItemChanged.connect(
            self.on_current_item_changed)
            
        self.table_widget.itemChanged.connect(self.on_item_changed)
        
        self.label = QLabel()
        self.label.setAlignment(Qt.AlignmentFlag.AlignCenter)
        
        layout.addWidget(self.table_widget)
        layout.addWidget(self.label)

    # 3 - Handle table widget events
    #     table selection changes:
    def on_current_item_changed(self, current, previous):
        # You have references to current and previously selected
        # table cells. previous can be None!
        self.label.setText('Selected cell value: {}'.format(current.text()))

    #     item value changes:
    def on_item_changed(self, item):
        self.label.setText('Cell value has changed: {}'.format(item.text()))


if __name__ == '__main__':

    if not QApplication.instance():
        app = QApplication(sys.argv)
    else:
        app = QApplication.instance()

    main_window = Window()
    main_window.show()

    sys.exit(app.exec())