我需要使用 PyQt 类显示数据QTableWidget
。但是可能有几十万行。显示整个工作表会使应用程序挂起......
所以我找到了一个解决方案,包括加载数据(意味着创建工作表)但隐藏大部分行,并且在移动滚动条时显示新行并隐藏以前的行。
在下面的代码中,我设置self.rowsShown = 50
并在初始化时显示了从 1 到 50 的行。我以前做过self.verticalScrollBar().actionTriggered.connect(self.refreshDisplay)
。
所以代码是:
def refreshDisplay(self):
"""
This is to refresh the display when the scrollbar is moved
"""
# Minimum is reached and a previous row exists
if self.verticalScrollBar().value() <= self.verticalScrollBar().minimum() and self.isRowHidden(self.firstRowShown-1):# Minimum is reached and a previous row exists
for row in xrange(self.lastRowShown-1, self.lastRowShown):
self.hideRow(row)
self.lastRowShown -= 1
for row in xrange(self.firstRowShown-1, self.firstRowShown):
self.showRow(row)
self.firstRowShown -= 1
# Maximum is reached and a next row exists
if self.verticalScrollBar().value() >= self.verticalScrollBar().maximum() and self.isRowHidden(self.lastRowShown+1):
for row in xrange(self.firstRowShown, self.firstRowShown+1):
self.hideRow(row)
self.firstRowShown += 1
for row in xrange(self.lastRowShown, self.lastRowShown+1):
self.showRow(row)
self.lastRowShown += 1
当我使用鼠标滚动或单击滚动条的按钮时,这非常有效。但是当我抓住滑块或使用键盘移动选定的案例时,我被挡在了显示的区域中。
此外,滚动区域的大小仅对应于所示的行。我想重新定义它以设置我自己的栏(例如,使用基于实际行数的大小),以便我可以快速移动到工作表的另一部分。但是滚动条的大小总是随着显示的行数而更新。
所以,我对你的期望是帮助我解决这两个问题,或者给我另一个想法来展示这么大的表格。也许我错过了一个在移动光标时已经具有加载/显示行功能的模块或类。
谢谢