我有一个QStandardItemModel,包含100,000条数据记录,以及一个QSortFilterProxyModel,用于过滤和排序功能。我想根据其中一列的值删除大量的记录,比如说100,000。
当前实现迭代源模型,测试相应列中的值,并调用removeRow。事实证明这是一个非常缓慢的方法,我不知道为什么(我已经关闭了源模型和sortfilterproxymodel的信号)。
什么是更有效的方法?
QSortFilterProxyModel可以帮助,例如通过创建要删除的记录选择,并使用removeRows?
谢谢, 安德烈亚斯
答案 0 :(得分:1)
QAbstractItemModel::removeRows()
是候选者,前提是行是连续的。如果模型按照您用于执行删除测试的列进行排序,那么您应该能够使用它。
答案 1 :(得分:1)
更有效的方法是使用QAbstractItemModel接口而不是使用QStandardItemModel来实现您自己的模型。然后,您可以构建自定义索引,这将有助于您在删除项目时提高性能。