赞
踩
QlistView类用于展示数据,它的子类是QListWIdget。QListView是基于模型(Model)的,需要程序来建立模型,然后再保存数据
QListWidget是一个升级版本的QListView,它已经建立了一个数据储存模型(QListWidgetItem),直接调用addItem()函数,就可以添加条目(Item)
方法 | 描述 |
---|---|
setModel() | 用来设置View所关联的Model,可以使用Python原生的list作为数据源Model |
selectedItem() | 选中Model的条目 |
isSelected() | 判断Model中的某条目是否被选中 |
信号 | 含义 |
---|---|
clicked | 当单击某项时,信号被发射 |
doubleClicked | 当双击某项时,信号被发射 |
import sys
from PyQt5.QtWidgets import QApplication,QWidget,QVBoxLayout,QListView,QMessageBox
from PyQt5.QtCore import QStringListModel
class ListViewDemo(QWidget):
def __init__(self,parent=None):
super(ListViewDemo, self).__init__(parent)
#设置初始大小与标题
self.resize(300,270)
self.setWindowTitle('QListView 例子')
#垂直布局
layout=QVBoxLayout()
#实例化列表视图
listview=QListView()
#实例化列表模型,添加数据
slm=QStringListModel()
self.qList=['Item 1','Item 2','Item 3','Item 4']
#设置模型列表视图,加载数据列表
slm.setStringList(self.qList)
#设置列表视图的模型
listview.setModel(slm)
#单击触发自定义的槽函数
listview.clicked.connect(self.clicked)
#设置窗口布局,加载控件
layout.addWidget(listview)
self.setLayout(layout)
def clicked(self,qModelIndex):
#提示信息弹窗,你选择的信息
QMessageBox.information(self,'ListWidget','你选择了:'+self.qList[qModelIndex.row()])
if __name__ == '__main__':
app=QApplication(sys.argv)
win=ListViewDemo()
win.show()
sys.exit(app.exec_())

效果如图
在这个例子中,当单击QListView控件中的Model中的一项时会弹出消息框(提示选中的是哪一项)
将QListView控件的clicked信号与自定义对象的clicked()槽函数进行绑定
listview.clicked.connect(self.clicked)
def clicked(self,qModelIndex):
#提示信息弹窗,你选择的信息
QMessageBox.information(self,'ListWidget','你选择了:'+self.qList[qModelIndex.row()])
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。