1

我正在尝试从我开发的程序中优化一种方法。

基本上,它是一个显示信息的 GUI(我使用 PyQt 库)。信息存储在 sqlite 数据库中。我使用 QSqlTableModel 和 QTableview 来显示这些信息。这是一个非常常见的组合。

数据库中的字段之一是布尔值,称为“新”。我要优化的方法的目的是将此布尔值设置为 0。

这是方法:

def markOneRead(self, element):

    """Slot to mark an article read"""

    print("\n")
    print("start markoneread")
    start_time = datetime.datetime.now()

    # Get the QTableView object (I have several)
    table = self.liste_tables_in_tabs[self.onglets.currentIndex()]

    # Save the current selected line
    line = table.selectionModel().currentIndex().row()

    print("before bdd change")
    elapsed_time = datetime.datetime.now() - start_time
    print(elapsed_time)

    # Change the data in the model
    # The 12th column is the field "new". I write 0
    # !!!!! Very long action
    table.model().setData(table.model().index(line, 12), 0)

    print("before searchbutton")
    elapsed_time = datetime.datetime.now() - start_time

输出是这样的:

before bdd change
0:00:00.000141
before searchbutton
0:00:03.064438

所以基本上,这一行:

table.model().setData(table.model().index(line, 12), 0)

执行需要 3 秒。那很长,我只是在更新数据库中的一个项目,应该不会那么长。我的数据库有 25000 个项目,但我认为它不会改变什么。

编辑:也许是因为模型立即执行更改,并尝试重新加载所有数据?

你知道如何解决这个问题吗?

编辑2:

实际上,问题来自重新加载数据。如果我更改模型的editStrategy:

model.setEditStrategy(QtSql.QSqlTableModel.OnManualSubmit)

现在不再需要 3 秒了,但是视图没有更新,在调用方法之后 new 仍然设置为 1。

所以我想知道是否有办法在模型更改后“重新加载”一个项目,一个索引?

4

2 回答 2

1

也许这有帮助:

和:

index = table.model().index(line, 12)
table.model().dataChanged.emit(index,index)

或者:

table.model().dataChanged.emit(table.model().index(line, 12),table.model().index(line, 12))

您可以定义受更改影响的项目,请参阅文档

通过table.model().dataChanged-signal 后的自动更新或重绘table.model.setData()应限制在由代表左上角和右下角子项的两个索引定义的区域内。如果两个索引相同,则只有一项受到影响。

于 2015-04-16T18:30:56.227 回答
0

QSqlTableModel很方便,但这不是魔术。我的猜测是执行更新语句需要大部分时间。尝试手动更新几行,看看会持续多久。

如果这也很慢,那么您可能需要在表上建立一个索引,以便 sqlite 可以更快地定位行。

于 2015-04-17T10:05:19.773 回答