在QTableView中可以使用自定义的数据模型来显示内容,通过
setModel
来绑定数据源。
QTableWidgetItem
对象来实现的。通常使用QTableWidget就能够满足我们的要求。名称 | 含义 |
---|---|
QStringListModel | 存储一组字符串 |
QStandarItemModel | 存储任意层次结构的数据 |
QDirModel | 对文件系统进行封装 |
QSqlTableModel | 对SQL中的表格进行封装 |
QSqlQueryModel | 对SQL的查询结果集进行封装 |
QSqlRelationalTableModel | 对带有foreign key的SQL表格进行封装 |
QSortFilterProxyModel | 对模型中的数据进行排序或过滤 |
import sys
from PyQt5 import QtCore
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *
class Win(QWidget):
def __init__(self):
super().__init__()
self.setGeometry(300, 300,500, 400)
self.setWindowTitle('QTableView的使用')
self.model = QStandardItemModel(4,4)
self.model.setHorizontalHeaderLabels(['标题1','标题2','标题3','标题4'])
for row in range(4):
for column in range(4):
item = QStandardItem('row%s,column%s'%(row,column))
self.model.setItem(row,column,item)
self.tableView = QTableView()
self.tableView.setModel(self.model)
dlgLayout = QVBoxLayout()
dlgLayout.addWidget(self.tableView)
self.setLayout(dlgLayout)
if __name__ == "__main__":
app = QApplication(sys.argv)
form = Win()
form.show()
sys.exit(app.exec_())
运行效果如下:
self.tableView.horizontalHeader().setStretchLastSection(True)
self.tableView.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
self.model.appendRow([QStandardItem('row%s,column%s'%(4,0)),QStandardItem('row%s,column%s'%(4,1)),QStandardItem('row%s,column%s'%(4,2)),QStandardItem('row%s,column%s'%(4,3))])
index = self.tableView.currentIndex()
print(index.row())
self.model.removeRow(index.row())
indexes = self.tableView.selectionMode().selection().indexes()
if len(indexes) > 0:
index = indexes[0]
self.model.removeRows(index,row(),1)