PYQT5-QTableWidget添加QComboBox控件并获取控件值

使用pyqt5编写的程序,在QTableWidget插入QComboBox控件并获取控件值

第一步:原理

QTableWidget是Qt程序中常用的显示数据表格的控件,其单元数据是通过QTableWidgetItem对象来实现的,使用QTableWidget时就需要QTableWidgetItem。整个表格就是用各个单元格构建起来的。

本程序在QTableWidget控件单元格中插入QTableWidgetItem,QComboBox控件,并可以修改单元格的不同值。通过控件提供的函数及循环,还可以遍历获取到整个QTableWidget表格中的所有值。

第二步:程序

import sys
from PyQt5.QtWidgets import *
 
class Table(QWidget):
    def __init__(self):
        super(Table, self).__init__()
        self.initUI()
    def initUI(self):
        self.setWindowTitle("QTableWidget例子")
        self.resize(400,300)
        layout=QVBoxLayout()
 
        #实现的效果是一样的,四行三列,所以要灵活运用函数,这里只是示范一下如何单独设置行列
        self.TableWidget=QTableWidget(2,2)
 
        # TableWidget = QTableWidget()
        # TableWidget.setRowCount(4)
        # TableWidget.setColumnCount(3)
 
        #设置水平方向的表头标签与垂直方向上的表头标签,注意必须在初始化行列之后进行,否则,没有效果
        self.TableWidget.setHorizontalHeaderLabels(['姓名','性别'])
        #Todo 优化1 设置垂直方向的表头标签
        #TableWidget.setVerticalHeaderLabels(['行1', '行2', '行3', '行4'])
 
        #TODO 优化 2 设置水平方向表格为自适应的伸缩模式
        ##TableWidget.horizontalHeader().setSectionResizeMode(QHeaderView.Stretch)
 
        #TODO 优化3 将表格变为禁止编辑
        #TableWidget.setEditTriggers(QAbstractItemView.NoEditTriggers)
 
        #TODO 优化 4 设置表格整行选中
        #TableWidget.setSelectionBehavior(QAbstractItemView.SelectRows)
 
        #TODO 优化 5 将行与列的高度设置为所显示的内容的宽度高度匹配
        #QTableWidget.resizeColumnsToContents(TableWidget)
        #QTableWidget.resizeRowsToContents(TableWidget)
 
        #TODO 优化 6 表格头的显示与隐藏
        #TableWidget.verticalHeader().setVisible(False)
        #TableWidget.horizontalHeader().setVisible(False)
 
        #TOdo 优化7 在单元格内放置控件
        # comBox=QComboBox()
        # comBox.addItems(['男','女'])
        # comBox.addItem('未知')
        # comBox.setStyleSheet('QComboBox{margin:3px}')
        # TableWidget.setCellWidget(0,1,comBox)
        #
        # searchBtn=QPushButton('修改')
        # searchBtn.setDown(True)
        # searchBtn.setStyleSheet('QPushButton{margin:3px}')
        # TableWidget.setCellWidget(0,2,searchBtn)
 
        #添加数据
        newItem=QTableWidgetItem('张三')
        self.TableWidget.setItem(0,0,newItem)
 
        newItem=QTableWidgetItem('李四')
        self.TableWidget.setItem(1,0,newItem)
 
        #TOdo 在单元格内放置控件
        comboxColumn=QComboBox()
        comboxColumn.addItems(['男','女'])
        comboxColumn.addItem('未知')
        self.TableWidget.setCellWidget(0,1,comboxColumn)
 
        comboxColumn=QComboBox()
        comboxColumn.addItems(['男','女'])
        comboxColumn.addItem('未知')
        self.TableWidget.setCellWidget(1,1,comboxColumn)
 
        layout.addWidget(self.TableWidget)
 
        self.button = QPushButton('获取表格值')
        self.button.clicked.connect(self.getValue)
        layout.addWidget(self.button)
 
        self.setLayout(layout)
 
    def getValue(self):
        print('getValue:')
        for idx in range(self.TableWidget.rowCount()):
            print('姓名:' + self.TableWidget.item(idx,0).text() + ',性别:' + self.TableWidget.cellWidget(idx,1).currentText())
 
 
if __name__ == '__main__':
    app=QApplication(sys.argv)
    win=Table()
    win.show()
    sys.exit(app.exec_())

第三步:运行

运行效果如下图,修改表格值后,点击 “获取表格值” 按钮,可以在命令行窗口中打印出整个表格的值。
PYQT5-QTableWidget添加QComboBox控件并获取控件值_第1张图片
————————————————
版权声明:本文为CSDN博主「suiyl2009」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/suiyl2009/article/details/104135791

你可能感兴趣的:(pyqt5,qt,pyqt5,python)