2

我有QtTableWidget7 列和很多行(大约 2000,但会增长到 5000 甚至更多)。

该数据是从数据库中检索的。查询和后处理用了不到 100 毫秒,所以这不是问题。

但是对于 7x2000 个项目,将项目插入表中需要很长时间(大约 30 秒)。

我试图尽可能地优化代码,但我不知道该怎么做了。

另外,我必须注意,当启动应用程序时,会加载具有相同数据集的同一张表,而且速度非常快。所以我相信这是一个渲染问题。

在文档中搜索阻止渲染的内容,我想出了该setUpdatesEnabled方法,但根本没有帮助。

以下是我用来构建表的代码:

setUpdatesEnabled(false);
blockSignals(true);
bool sort = isSortingEnabled();
setSortingEnabled(false);
// rebuild headers.
buildHeaders(); // take less than 1ms.
// rebuild grid.
int oldRowCount = rowCount();
setRowCount(sml->length()); // take less than 1ms.
ListIterator<StoredMetadata> it(sml); // sml is a list with the data to be displayed.
int row = 0;
while ( it.hasNext() ) {
    AudioLife::StoredMetadata *sm = it.next();
    if ( row >= oldRowCount ) {
        setItem(row, 0, new QTableWidgetItem(sm->artist));
        setItem(row, 1, new QTableWidgetItem(sm->album));
        setItem(row, 2, new QTableWidgetItem(sm->name));
        setItem(row, 3, new QTableWidgetItem(sm->number > 0 ? QString().setNum(sm->number) : ""));
        setItem(row, 4, new QTableWidgetItem(sm->year > 0 ? QString().setNum(sm->year) : ""));
        setItem(row, 5, new QTableWidgetItem(sm->genre));
        // commenting the following line does not improve performance.
        verticalHeader()->resizeSection(row, defaultRowHeight());
    } else {
        item(row, 0)->setText(sm->artist);
        item(row, 1)->setText(sm->album);
        item(row, 2)->setText(sm->name);
        item(row, 3)->setText(sm->number > 0 ? QString().setNum(sm->number) : "");
        item(row, 4)->setText(sm->year > 0 ? QString().setNum(sm->year) : "");
        item(row, 5)->setText(sm->genre);
    }
    item(row, 0)->setData(Qt::UserRole, QVariant(sm->id));
    row++;
}
setUpdatesEnabled(true);
blockSignals(false);
setSortingEnabled(sort);

有人有任何线索吗?

4

1 回答 1

2

考虑为您的表模型子类化QSqlTableModelQSqlQueryModel让框架为您显示项目,而不是手动插入/设置小部件的项目

[编辑]:或直接QSqlTableModel用作您的表格模型

参考:Using-QSqlTableModel-To-Display-an-SQL-viewQSQLTableModel 继承者和 QTableView,以及一些示例代码here

于 2013-05-29T06:56:47.567 回答