如何使用 cellWidget 处理来自 QTableWidget 单元的信号

Posted

技术标签:

【中文标题】如何使用 cellWidget 处理来自 QTableWidget 单元的信号【英文标题】:how to work signals from QTableWidget cell with cellWidget 【发布时间】:2020-07-13 11:28:10 【问题描述】:

我在 QTableWidget 上工作过,问题是如果单元格是由 QTableWidgetItem 设置的,则信号“itemChanged”运行良好,可以轻松获取行/列/文本,但如果单元格是由 cellWidget 设置的,例如 QLineEdit,那么信号“itemChanged”不会'T工作,QlineEdit本身的歌唱型'TextChanged'还有工作,但它太难了,如果数百个QlineEdit也是如此,可以像符合物品一样工作?请帮忙,谢谢。

代码如下:

import sys
from PyQt5.QtWidgets import *

class Table(QWidget):
    def __init__(self):
        super(Table, self).__init__()
        self.initUI()
    def initUI(self):
        self.setWindowTitle("QTableWidget Example")
        self.resize(400,300)
        self.layout=QHBoxLayout()
        self.TableWidget=QTableWidget(4,3)


        self.TableWidget.setHorizontalHeaderLabels(['Nmae','Sex','Weight(kG)'])

        # self.newItem=QTableWidgetItem('Jack')
        # self.TableWidget.setItem(0,0,self.newItem)

        # self.newItem=QTableWidgetItem('Male')
        # self.TableWidget.setItem(0,1,self.newItem)

        # self.newItem=QTableWidgetItem('160')
        # self.TableWidget.setItem(0,2,self.newItem)

        self.newItem=QLineEdit('Jack')        
        self.TableWidget.setCellWidget(0,0,self.newItem)        
        self.newItem.textChanged.connect(self.txtChange)

        self.newItem=QLineEdit('Male')        
        self.TableWidget.setCellWidget(0,1,self.newItem)        

        self.newItem=QLineEdit('160')        
        self.TableWidget.setCellWidget(0,2,self.newItem)        

        self.layout.addWidget(self.TableWidget)

        self.setLayout(self.layout)
        self.TableWidget.itemChanged.connect(self.changeTest)

    def changeTest(self,item):
        # print('test')
        print(item.text())

    def txtChange(self,txt):
        print(txt)

if __name__ == '__main__':
    app=QApplication(sys.argv)
    win=Table()
    win.show()
    sys.exit(app.exec_())

【问题讨论】:

【参考方案1】:

一种可能的解决方案是不使用 cellWidget,而是永久打开委托编辑器:

class StyledItemDelegate(QStyledItemDelegate):
    def createEditor(self, parent, option, index):
        return QLineEdit(parent)


class Table(QWidget):
    def __init__(self):
        super(Table, self).__init__()
        self.initUI()

    def initUI(self):
        self.setWindowTitle("QTableWidget Example")
        self.resize(400, 300)

        self.tableWidget = QTableWidget(4, 3)
        delegate = StyledItemDelegate(self)
        self.tableWidget.setItemDelegate(delegate)

        self.tableWidget.setHorizontalHeaderLabels(["Nmae", "Sex", "Weight(kG)"])
        self.tableWidget.itemChanged.connect(self.changeTest)

        lay = QHBoxLayout(self)
        lay.addWidget(self.tableWidget)

        it = QTableWidgetItem("Jack")
        self.tableWidget.setItem(0, 0, it)
        self.tableWidget.openPersistentEditor(it)

        it = QTableWidgetItem("Male")
        self.tableWidget.setItem(0, 1, it)
        self.tableWidget.openPersistentEditor(it)

        it = QTableWidgetItem("160")
        self.tableWidget.setItem(0, 2, it)
        self.tableWidget.openPersistentEditor(it)

    def changeTest(self, item):
        print(item.text())

【讨论】:

以上是关于如何使用 cellWidget 处理来自 QTableWidget 单元的信号的主要内容,如果未能解决你的问题,请参考以下文章

如何让 cellWidgets 中的 dojo gridx dojo 小部件自动写入商店?

QTablewidget 在 PyQt5 中不显示新的 cellWidgets

qt的程序异常退出 求救

qtabwidget切换tab如何修改

如何使用来自inheritedWidget 的流处理导航?

qtablewidget加入QcomboBox控件如何读取内容