如何使用我自己的代码对QTableWidget进行排序?

时间:2010-02-20 23:34:58

标签: qt sorting pyqt qt4 qtableview

我在Linux上使用Qt4.5.2。我有一个简单的QTableWidget,其中一列以人性化的格式显示日期。不幸的是,“人性化日期”并不容易正确排序。因此,在QTableWidget中,我保留一个隐藏列,其中UNIX时间戳对应于该日期。

我试图确保每当发出对DATE列进行排序的请求时,实际上在(不可见的)TIMESTAMP列上进行排序。我尝试通过从QTableWidget继承并定义:

重新实现sortByColumn(这是在Python中)
   def sortByColumn(self, col, order):
       print 'got request to sort col %d in order %s' % (col, str(order) )

然而,每当我点击我的表格的一个标题时,就会继续调用正常的排序方法。

如何覆盖它?

1 个答案:

答案 0 :(得分:7)

您可以派生自己的QTableWidgetItem类,然后编写自己的__lt__运算符。这样可以减少对额外色谱柱的需求。有点像:

from PyQt4 import QtCore, QtGui
import sys
import datetime

class MyTableWidgetItem(QtGui.QTableWidgetItem):
    def __init__(self, text, sortKey):
        #call custom constructor with UserType item type
        QtGui.QTableWidgetItem.__init__(self, text, QtGui.QTableWidgetItem.UserType)
        self.sortKey = sortKey

    #Qt uses a simple < check for sorting items, override this to use the sortKey
    def __lt__(self, other):
        return self.sortKey < other.sortKey

app = QtGui.QApplication(sys.argv)
window = QtGui.QMainWindow()
window.setGeometry(0, 0, 400, 400)

table = QtGui.QTableWidget(window)
table.setGeometry(0, 0, 400, 400)
table.setRowCount(3)
table.setColumnCount(1)

date1 = datetime.date.today()
date2 = datetime.date.today() + datetime.timedelta(days=1)
date3 = datetime.date.today() + datetime.timedelta(days=2)

item1 = MyTableWidgetItem(str(date1.strftime("%A %d. %B %Y")), str(date1))
item2 = MyTableWidgetItem(str(date2.strftime("%A %d. %B %Y")), str(date2))
item3 = MyTableWidgetItem(str(date3.strftime("%A %d. %B %Y")), str(date3))

table.setItem(0, 0, item1)
table.setItem(2, 0, item2)
table.setItem(1, 0, item3)
table.setSortingEnabled(True)

window.show()
sys.exit(app.exec_())

这为我产生了正确的结果,你可以自己运行来验证。单元格文本显示“星期六20二月2010”等文本,但是当您对列进行排序时,它将按sortKey字段正确排序,即“2010-02-20”(iso格式化)。

哦,还应该注意,这不适用于PySide,因为看起来__lt__运算符没有绑定,就像PyQt4一样。我花了一个在尝试调试它为什么不工作时,然后我从PySide切换到PyQt4,它工作正常。您可能会注意到此处未列出__lt__

http://www.pyside.org/docs/pyside/PySide/QtGui/QTableWidgetItem.html

但它在这里:

http://doc.qt.digia.com/4.5/qtablewidgetitem.html#operator-lt