PySide2 Common List Components -- QTableView QListView

1. QListView

Official Document: https://doc.qt.io/qt-5/qlistview.html

1.1 QListView shields double - click editing

1
listView.setEditTriggers(QAbstractItemView.NoEditTriggers)

1.2 QListView Display Data

1
2
3
4
slm = QStringListModel()  # 创建mode
self.qList = ['Item 1', 'Item 2', 'Item 3', 'Item 4'] # 添加的数组数据
slm.setStringList(self.qList) # 将数据设置到model
listView.setModel(slm) # 绑定 listView 和 model

1.3 QListView Bind click events

1
2
3
4
5
6
listView.clicked.connect(self.handle_clicked_list)  # listview 的点击事件


def clicked_list(self, qModelIndex):
QMessageBox.information(self, "QListView", "你选择了: " + self.qList[qModelIndex.row()])
print("点击的是:" + str(qModelIndex.row()))

1.4 QListView Sample

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
from PySide2.QtWidgets import QApplication, QWidget, QVBoxLayout, QListView, QMessageBox
from PySide2.QtCore import QStringListModel

import sys


class ListViewDemo(QWidget):
def __init__(self, parent=None):
super(ListViewDemo, self).__init__(parent)
self.setWindowTitle("QListView 例子")
self.resize(300, 270)

layout = QVBoxLayout()
listView = QListView() # 创建一个listview对象

slm = QStringListModel() # 创建mode
self.qList = ['Item 1', 'Item 2', 'Item 3', 'Item 4'] # 添加的数组数据
slm.setStringList(self.qList) # 将数据设置到model
listView.setModel(slm) # 绑定 listView 和 model

listView.clicked.connect(self.clicked_list) # listview 的点击事件
layout.addWidget(listView) # 将list view添加到layout
self.setLayout(layout) # 将lay 添加到窗口

def clicked_list(self, qModelIndex):
QMessageBox.information(self, "QListView", "你选择了: " + self.qList[qModelIndex.row()])
print("点击的是:" + str(qModelIndex.row()))


if __name__ == "__main__":
app = QApplication(sys.argv)

win = ListViewDemo()
win.show()

sys.exit(app.exec_())

2. QTableWidget

Official Document: https://doc.qt.io/qt-5.15/QTableWidget.html

2.1 QTableWidget shields double clicks on a item

1
2
item = table_widget.item(index, column)
item.setFlags(QtCore.Qt.ItemIsEnabled)

2.2 QTableWidget add a row data

1
2
3
4
5
6
7
# Insert Row
new_row_index = table_widget.rowCount()
table_widget.insertRow(new_row_index)
# Update Row Data
table_widget.setItem(new_row_index, 0, QTableWidgetItem('Data0'))
table_widget.setItem(new_row_index, 1, QTableWidgetItem('Data1'))
table_widget.setItem(new_row_index, 2, QTableWidgetItem('Data2'))

2.3 QTableWidget gets the selected item

1
table_widget.selectedIndexes()

2.4 QTableWidget select the entire row

Sometimes choosing a item is not what we want.

In Qt Designer, we can modify:
selectionBehavior > SelectItems

After the modification:


PySide2 Common List Components -- QTableView QListView
https://www.hardyhu.cn/2022/08/10/PySide2-Common-List-Components-QTableView-QListView/
Author
John Doe
Posted on
August 10, 2022
Licensed under