QListView列表视图可以用来以列表的形式来展示数据。在Qt中使用Model-View结构来处理数据与视图之间的关系,Model负责数据的存取,View负责数据的展示, 二者之间数据的交互则是通过委托(delegate)来实现。
QT提供了一些现成的models用于处理数据项:
QListView是Model-View框架中的一个类,是Qt Model-View框架的组成部分,QListView实现了QAbstractItemView类定义的接口,以使其能够显示从QAbstractItemModel类派生的模型提供的数据。
QListView常用方法:
QListView常用信号:
QListView类继承关系:
使用QStandardItemModel作为QListView 所使用的模型,在QStandardItemModel中每个QStandardItem条目添加一个图标和文本。完整代码如下:
importsys,osfromPyQt5importQtCore,QtGui,QtWidgetsfromPyQt5.QtCoreimportQtfromPyQt5.QtGuiimportQIcon,QStandardItem,QStandardItemModelfromPyQt5.QtWidgetsimport(QApplication,QWidget,QListView,QLabel,QVBoxLayout)classDemoListView(QWidget):def__init__(self,parent=None):super(DemoListView,self).__init__(parent)#设置窗口标题self.setWindowTitle('实战PyQt5:QListViewDemo!')#设置窗口大小self.resize(480,360)self.initUi()definitUi(self):vLayout=QVBoxLayout(self)lv=QListView(self)slm=QStandardItemModel()self.sports=[{'img':'/images/basketball.png','title':'篮球'},{'img':'/images/football.png','title':'足球'},{'img':'/images/rugby-ball.png','title':'橄榄球'},{'img':'/images/valley-ball.png','title':'排球'}]forsportinself.sports:item=QStandardItem(QIcon(os.path.dirname(__file__)+sport['img']),sport['title'])slm.appendRow(item)lv.setModel(slm)lv.clicked.connect(self.onListViewClicked)self.label=QLabel(self)vLayout.addWidget(lv)vLayout.addWidget(self.label)self.setLayout(vLayout)#设置选中第一行lv.setCurrentIndex(slm.index(0,0))self.label.setText('当前选择为:'+self.sports[0]['title'])defonListViewClicked(self,index):#显示选中的x信息self.label.setText('当前选择为:'+self.sports[index.row()]['title'])if__name__=='__main__':app=QApplication(sys.argv)window=DemoListView()window.show()sys.exit(app.exec())
运行结果如下图:
测试QListView
以上就是qt listview详细用法(listview添加多列)的相关内容了,更多精彩请关注我们!!
上一篇:虞怎么读同音字(虞怎么读)