文章目录
QListView是PyQt(包括PyQt5和PyQt6)中的一个强大控件,用于展示列表数据。它基于模型/视图/委托(Model/View/Delegate)架构,提供了灵活的数据展示和处理能力。以下是一个关于QListView的全面教程:
一、安装PyQt
首先,确保已经安装了PyQt5或PyQt6。如果没有安装,可以使用pip进行安装:
pip install PyQt5 # 或者 pip install PyQt6
二、导入必要的模块
在使用QListView之前,需要导入必要的PyQt模块。例如:
import sys
from PyQt5.QtWidgets import QApplication, QListView, QWidget, QVBoxLayout # PyQt5用户
# 或者
# from PyQt6.QtWidgets import QApplication, QListView, QWidget, QVBoxLayout # PyQt6用户
from PyQt5.QtGui import QStandardItemModel, QStandardItem # PyQt5用户,用于创建和管理模型中的数据
# 或者
# from PyQt6.QtCore import QStringListModel # PyQt6用户,另一个常用的模型类
三、创建QListView和模型
QListView本身不存储数据,而是通过与数据模型关联来展示数据。常用的数据模型有QStandardItemModel和QStringListModel。
使用QStandardItemModel
class ListViewExample(QWidget):
def __init__(self):
super().__init__()
self.initUI()
def initUI(self):
self.listView = QListView(self)
self.model = QStandardItemModel()
# 添加一些项目到模型中
items = ["Item 1", "Item 2", "Item 3", "Item 4"]
for item in items:
standardItem = QStandardItem(item)
self.model.appendRow(standardItem)
self.listView.setModel(self.model)
layout = QVBoxLayout()
layout.addWidget(self.listView)
self.setLayout(layout)
self.setWindowTitle('QListView Example')
# 主程序
if __name__ == '__main__':
app = QApplication(sys.argv)
ex = ListViewExample()
ex.show()
sys.exit(app.exec_())
使用QStringListModel
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow, QListView # PyQt5用户
# 或者
# from PyQt6.QtWidgets import QApplication, QMainWindow, QListView # PyQt6用户
from PyQt5.QtGui import QStringListModel # PyQt5用户
# 或者
# from PyQt6.QtCore import QStringListModel # PyQt6用户
app = QApplication(sys.argv)
main_window = QMainWindow()
main_window.setWindowTitle("QListView 示例")
main_window.setGeometry(100, 100, 400, 300)
list_view = QListView(main_window)
list_view.setGeometry(50, 50, 300, 200)
model = QStringListModel()
data = ["苹果", "香蕉", "橙子", "葡萄", "草莓"]
model.setStringList(data)
list_view.setModel(model)
main_window.show()
sys.exit(app.exec_())
四、QListView的常用方法和信号
常用方法
setModel(Model)
: 用来设置View所关联的Model。selectedItem(n)
: 选中Model中的条目n(注意:这个方法不是QListView的标准方法,可能是某些特定上下文或自定义扩展中的方法,标准方法是通过模型来获取选中项)。isSelected()
: 判断Model中的某条目是否被选中(同样,这个方法可能不是QListView的直接方法,而是通过模型来判断)。
常用信号
clicked
: 当单击某项时发送。doubleClicked
: 当双击某项时发送。
五、自定义QListView
QListView支持自定义项的显示方式,这通常通过实现自定义的委托(QStyledItemDelegate或QItemDelegate)来完成。自定义委托可以重写paint()
和sizeHint()
方法来控制项的绘制和大小。
六、QListView的常用设置
- 设置项间距:
setSpacing(int spacing)
- 设置显示模式:
setViewMode(QListView.ViewMode mode)
,可以是列表模式(ListMode)或图标模式(IconMode)。 - 设置是否允许拖动:
setDragEnabled(bool enable)
- 设置选择模式:
setSelectionMode(QAbstractItemView.SelectionMode mode)
,可以是单选、多选等。
七、示例:添加、删除和排序功能
以下是一个包含添加、删除和排序功能的QListView示例:
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QVBoxLayout, QListView, QPushButton, QMessageBox
from PyQt5.QtGui import QStandardItemModel, QStandardItem
class QListviewDemo(QWidget):
def __init__(self, *args, **kwargs):
super(QListviewDemo, self).__init__(*args, **kwargs)
self.setWindowTitle("QListviewDemo")
self.resize(400, 400)
self.layout = QVBoxLayout(self)
self.qlistview = QListView()
self.layout.addWidget(self.qlistview)
self.mode = QStandardItemModel(5, 1)
for i in range(self.mode.rowCount()):
item = QStandardItem("item%d" % i)
self.mode.setItem(i, 0, item)
self.mode.insertRow(5, QStandardItem("item0"))
self.qlistview.setModel(self.mode)
hlayout = QVBoxLayout()
self.add_btn = QPushButton("增", clicked=self.on_add_btn_clicked)
self.del_btn = QPushButton("删", clicked=self.on_del_btn_clicked)
self.sort_btn = QPushButton("排序", clicked=self.on_sort_btn_clicked)
hlayout.addWidget(self.add_btn)
hlayout.addWidget(self.del_btn)
hlayout.addWidget(self.sort_btn)
self.layout.addLayout(hlayout)
def on_add_btn_clicked(self):
num = self.mode.rowCount()
self.mode.appendRow(QStandardItem("item%d" % (num + 1)))
def on_del_btn_clicked(self):
num = self.mode.rowCount()
if num > 0:
self.mode.removeRow(num - 1)
def on_sort_btn_clicked(self):
self.mode.sort(0)
if __name__ == '__main__':
app = QApplication(sys.argv)
test = QListviewDemo()
test.show()
sys.exit(app.exec_())
在这个示例中,我们创建了一个QListView,并为其添加了一个QStandardItemModel作为数据模型。然后,我们添加了三个按钮来实现添加、删除和排序功能。
总的来说,QListView是一个功能强大的控件,用于展示和操作列表数据。通过了解其基本原理和常用方法,可以轻松地将其集成到PyQt应用程序中。