python – 使用QTableWidget显示一个巨大的工作表
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了python – 使用QTableWidget显示一个巨大的工作表,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含1957字,纯文字阅读大概需要3分钟。
内容图文
我需要使用PyQt类QTableWidget显示数据.但可能会有数十万行.显示整个工作表使应用程序挂起…
所以我找到了一个解决方案,包括加载数据(意味着创建工作表)但隐藏了大部分行,并且在移动滚动条时,显示新行并隐藏以前的行.
在下面的代码中,我设置了self.rowsShown = 50,并且在init处显示了从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
当我使用鼠标滚动或单击滚动条的按钮时,这非常有效.但是当我抓住滑块或使用键盘移动所选的外壳时,我在所示区域被阻挡.
此外,滚动区域的大小对应于仅显示的行.我想重新设置它来设置我自己的栏(例如,基于实际行数的大小),以便我可以快速移动到工作表的另一部分.但滚动条的大小始终使用显示的行数进行更新.
所以,我对你的期望是帮助我解决这两个问题,或者给我另一个想法来展示如此庞大的表格.也许我错过了一个模块或类,它已经具有在移动光标时加载/显示行的功能.
谢谢
解决方法:
我编写了一个工具,在类似Excel的表中显示10 ^ 6行,没有资源问题.解决方案是使用QTableView和QAbstractTableModel.您必须从QAbstractTableModel派生并实现它需要您实现的必要功能(我记得headerData和数据,但我认为还有更多).然后,通过执行view.setModel(model)将模型插入到视图中.有关如何完成此操作的更多信息,请参见here.
内容总结
以上是互联网集市为您收集整理的python – 使用QTableWidget显示一个巨大的工作表全部内容,希望文章能够帮你解决python – 使用QTableWidget显示一个巨大的工作表所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。