python GUI庫(kù)圖形界面開發(fā)之PyQt5表格控件QTableView詳細(xì)使用方法與實(shí)例
PyQt5表格控件QTableView簡(jiǎn)介
在通常情況下,一個(gè)應(yīng)用需要和一批數(shù)據(jù)進(jìn)行交互,然后以表格的形式輸出這些信息,這時(shí)就需要用到QTableView類了,在QTableView中可以使用自定義的數(shù)據(jù)模型來(lái)顯示內(nèi)容,通過setModel來(lái)綁定數(shù)據(jù)源
QTableWidget繼承自QTableView,主要區(qū)別是QTableView可以使用自定義的數(shù)據(jù)模型來(lái)顯示內(nèi)容(先通setModel來(lái)綁定數(shù)據(jù)源),而QTableWidget自能使用標(biāo)準(zhǔn)的數(shù)據(jù)模型,并且其單元格數(shù)據(jù)是通過QTableWidgetItem對(duì)象實(shí)現(xiàn)的,通常QTableWidget就能夠滿足我們的要求
QTableView可用的模式
QTableView控件可以綁定一個(gè)模型數(shù)據(jù)用來(lái)更新控件上的內(nèi)容
名稱 | 含義 |
---|---|
QStringListModel | 儲(chǔ)存一組字符串 |
QstandardItemModel | 存儲(chǔ)任意層次結(jié)構(gòu)的數(shù)據(jù) |
QDirModel | 對(duì)文件系統(tǒng)進(jìn)行封裝 |
QSqlQueryModel | 對(duì)SQL的查詢結(jié)果集進(jìn)行封裝 |
QSqlTableModel | 對(duì)SQL中的表格進(jìn)行封裝 |
QSqlRelationalTableModel | 對(duì)帶有foreign key的SQL表格進(jìn)行封裝 |
QSortFilterProxyModel | 對(duì)模型中的數(shù)據(jù)進(jìn)行排序或過濾 |
QTableView的使用實(shí)例
import sys from PyQt5.QtCore import * from PyQt5.QtWidgets import * from PyQt5.QtGui import * class Table(QWidget): def __init__(self,parent=None): super(Table, self).__init__(parent) #設(shè)置標(biāo)題與初始大小 self.setWindowTitle('QTableView表格視圖的例子') self.resize(500,300) #設(shè)置數(shù)據(jù)層次結(jié)構(gòu),4行4列 self.model=QStandardItemModel(4,4) #設(shè)置水平方向四個(gè)頭標(biāo)簽文本內(nèi)容 self.model.setHorizontalHeaderLabels(['標(biāo)題1','標(biāo)題2','標(biāo)題3','標(biāo)題4']) # #Todo 優(yōu)化2 添加數(shù)據(jù) # self.model.appendRow([ # QStandardItem('row %s,column %s' % (11,11)), # QStandardItem('row %s,column %s' % (11,11)), # QStandardItem('row %s,column %s' % (11,11)), # QStandardItem('row %s,column %s' % (11,11)), # ]) for row in range(4): for column in range(4): item=QStandardItem('row %s,column %s'%(row,column)) #設(shè)置每個(gè)位置的文本值 self.model.setItem(row,column,item) #實(shí)例化表格視圖,設(shè)置模型為自定義的模型 self.tableView=QTableView() self.tableView.setModel(self.model) # #todo 優(yōu)化1 表格填滿窗口 # #水平方向標(biāo)簽拓展剩下的窗口部分,填滿表格 # self.tableView.horizontalHeader().setStretchLastSection(True) # #水平方向,表格大小拓展到適當(dāng)?shù)某叽? # self.tableView.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch) # # #TODO 優(yōu)化3 刪除當(dāng)前選中的數(shù)據(jù) # indexs=self.tableView.selectionModel().selection().indexes() # print(indexs) # if len(indexs)>0: # index=indexs[0] # self.model.removeRows(index.row(),1) #設(shè)置布局 layout=QVBoxLayout() layout.addWidget(self.tableView) self.setLayout(layout) if __name__ == '__main__': app=QApplication(sys.argv) table=Table() table.show() sys.exit(app.exec_())
運(yùn)行程序,顯示效果如圖
從圖中可以看出,表格并沒有填滿窗口,每列都可以自由拉伸,但是可能會(huì)出現(xiàn)滾動(dòng)條
優(yōu)化1:需要表格填充滿窗口,可以添加一下代碼
#水平方向標(biāo)簽拓展剩下的窗口部分,填滿表格 self.tableView.horizontalHeader().setStretchLastSection(True) #水平方向,表格大小拓展到適當(dāng)?shù)某叽? self.tableView.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
效果如下
優(yōu)化2:添加數(shù)據(jù)
#Todo 優(yōu)化2 添加數(shù)據(jù) self.model.appendRow([ QStandardItem('row %s,column %s' % (11,11)), QStandardItem('row %s,column %s' % (11,11)), QStandardItem('row %s,column %s' % (11,11)), QStandardItem('row %s,column %s' % (11,11)), ])
效果如圖
優(yōu)化3:刪除當(dāng)前選中的數(shù)據(jù)
indexs=self.tableView.selectionModel().selection().indexes() print(indexs) if len(indexs)>0: index=indexs[0] self.model.removeRows(index.row(),1)
本文主要介紹了PyQt5表格控件QTableView詳細(xì)使用方法與實(shí)例,更多關(guān)于這方面的知識(shí)請(qǐng)查看下面的相關(guān)鏈接
相關(guān)文章
對(duì)python中的try、except、finally 執(zhí)行順序詳解
今天小編就為大家分享一篇對(duì)python中的try、except、finally 執(zhí)行順序詳解,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2019-02-02python多項(xiàng)式擬合之np.polyfit 和 np.polyld詳解
這篇文章主要介紹了python多項(xiàng)式擬合之np.polyfit 和 np.polyld的實(shí)例代碼,python數(shù)據(jù)擬合主要可采用numpy庫(kù),庫(kù)的安裝可直接用pip install numpy等,需要的朋友跟隨小編一起學(xué)習(xí)吧2020-02-02使用Python導(dǎo)出Excel圖表以及導(dǎo)出為圖片的方法
這篇文章主要介紹了使用Python導(dǎo)出Excel圖表以及導(dǎo)出為圖片的方法,Python相關(guān)模塊在Windows下操作office非常方便,需要的朋友可以參考下2015-11-11Python日期時(shí)間處理庫(kù)dateutil詳解
dateutil 為 Python 標(biāo)準(zhǔn)庫(kù) datetime 提供了強(qiáng)大的擴(kuò)展,這篇文章主要介紹了Python日期時(shí)間處理庫(kù)dateutil,需要的朋友可以參考下2022-09-09刪除DataFrame中值全為NaN或者包含有NaN的列或行方法
今天小編就為大家分享一篇?jiǎng)h除DataFrame中值全為NaN或者包含有NaN的列或行方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧2018-11-11常見的在Python中實(shí)現(xiàn)單例模式的三種方法
這篇文章主要介紹了常見的在Python中實(shí)現(xiàn)單例模式的三種方法,單例模式在各個(gè)編程語(yǔ)言的學(xué)習(xí)中都是需要掌握的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-04-0412個(gè)Pandas/NumPy中的加速函數(shù)使用總結(jié)
在本文中,數(shù)據(jù)和分析工程師?Kunal?Dhariwal?為我們介紹了?12?種?Numpy?和?Pandas?函數(shù),這些高效的函數(shù)會(huì)令數(shù)據(jù)分析更為容易、便捷2022-09-09