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

lar*_*els 6 sorting qt qt4 pyqt 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) )
Run Code Online (Sandbox Code Playgroud)

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

我怎样才能覆盖它?

swa*_*son 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_())
Run Code Online (Sandbox Code Playgroud)

这为我产生了正确的结果,你可以自己运行来验证.单元格文本显示"星期六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