Как отсортировать QTableWidget с моим собственным кодом? - PullRequest
6 голосов
/ 21 февраля 2010

Я использую Qt4.5.2 в Linux. У меня есть простой QTableWidget, в котором столбец отображает даты в удобном для человека формате. К сожалению, «дружественные человеку даты» нелегко правильно отсортировать. Итак, в QTableWidget я храню скрытый столбец с отметкой времени UNIX, соответствующей этой дате.

Я пытаюсь убедиться, что всякий раз, когда выдается запрос на сортировку по столбцу DATE, в действительности сортировка выполняется по (невидимому) столбцу TIMESTAMP. Я попытался переопределить sortByColumn (это в Python), создав подклассы из QTableWidget и определив:

   def sortByColumn(self, col, order):
       print 'got request to sort col %d in order %s' % (col, str(order) )

Тем не менее, всякий раз, когда я нажимаю на один из заголовков моей таблицы, нормальный метод сортировки продолжает вызываться.

Как я могу переопределить это?

1 Ответ

7 голосов
/ 21 февраля 2010

Вы можете получить свой собственный класс 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

...