QT QStandardItemModel 数据修改时 触发

1. QT QStandardItemModel没有直接对应的数据修改信号。而tableWidget的数据修改信号非常容易触发信号循环。

而采用currnetChanged的方法,却可以避免信号循环。但是判断单元是否修改仍然需要自己处理。

2. 以下是处理函数。

void Wells::on_wellCurrentChanged(const QModelIndex &current, const QModelIndex &previous)
{
    //当前选择变换
    ui->label_before->setText(lastStr);
    if (previous.isValid())
    {
        //ui->label_after->setText(wellModel->itemFromIndex(previous)->text());
        afterStr = wellModel->itemFromIndex(previous)->text();
        ui->label_after->setText(afterStr);
        qDebug()<<previous.column();
    };
    //比较上一项有无修改。其中lastStr中保存的是未修改前上一个的字符。afterStr中保存的是目前状态上一项的字符。
    if (lastStr == afterStr)
    {
        qDebug()<<"没有修改";
    }
    else
    {
        qDebug()<<"上一项【已经】修改。";
    };
    //在给上一个赋值
    if (current.isValid())
    {
        lastStr = wellModel->itemFromIndex(current)->text();
    };  //这种方式确实可以 对比 数据的前后变化 */

}

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果您想在 Qt TableView 中修改单元格的文字后触发槽函数,可以使用 `QItemDelegate` 类和 `dataChanged` 信号来实现。 首先,您需要创建一个自定义的 `QItemDelegate` 类,该类将处理单元格的编辑和显示操作。然后,您需要将该委托类与 TableView 的单元格绑定,以便在编辑单元格使用。 在 `QItemDelegate` 类中,您需要实现 `createEditor` 函数和 `setEditorData` 函数,以便在编辑单元格创建编辑器并设置其初始值。还需要实现 `setModelData` 函数,以便将编辑器中的值保存回数据模型。 下一步是连接 `dataChanged` 信号和您的槽函数。该信号在模型中的数据修改发出,因此您可以在槽函数中处理这些更改。 以下是一个简单的示例代码,演示了如何在 Qt TableView 中修改单元格的文字后触发槽函数: ```python from PyQt5.QtCore import Qt, QModelIndex from PyQt5.QtWidgets import QApplication, QTableView, QStandardItemModel, QItemDelegate, QLineEdit class MyDelegate(QItemDelegate): def createEditor(self, parent, option, index): editor = QLineEdit(parent) return editor def setEditorData(self, editor, index): value = index.model().data(index, Qt.EditRole) editor.setText(value) def setModelData(self, editor, model, index): value = editor.text() model.setData(index, value, Qt.EditRole) class MyTableView(QTableView): def __init__(self): super().__init__() self.model = QStandardItemModel(4, 4) self.setModel(self.model) self.setItemDelegate(MyDelegate(self)) self.model.dataChanged.connect(self.handle_data_changed) def handle_data_changed(self, index: QModelIndex, first: QModelIndex, last: QModelIndex): print(f"Data changed: row={index.row()}, column={index.column()}, value={index.data()}") if __name__ == '__main__': app = QApplication([]) table_view = MyTableView() table_view.show() app.exec_() ``` 在这个例子中,我们创建了一个自定义的 `MyDelegate` 类,用于处理单元格的编辑和显示操作。然后,我们将该委托类与 `MyTableView` 的单元格绑定,并将 `dataChanged` 信号连接到 `handle_data_changed` 槽函数。 当我们在 TableView 中编辑单元格,`dataChanged` 信号会被发出,并在 `handle_data_changed` 槽函数中进行处理。在这个例子中,我们只是简单地将修改数据打印到控制台上。 需要注意的是,当单元格被编辑,`createEditor` 函数会创建一个编辑器,并将其显示在单元格中。当编辑器被关闭,`setModelData` 函数会将编辑器中的值保存回数据模型。在这个例子中,我们使用了一个简单的 QLineEdit 编辑器来编辑单元格的值,您可以根据实际需求选择不同的编辑器。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值