How to sort a QTableView by a column?

Martin Drozdik picture Martin Drozdik · Jul 23, 2012 · Viewed 33.7k times · Source

I am using the QTableView to display a QAbstractTableModel:

#include <QtGui/QApplication>
#include <QAbstractTableModel>
#include <QTableView>

class TestModel : public QAbstractTableModel
{
public:
    int rowCount(const QModelIndex &parent = QModelIndex()) const
    {
        return 2;
    }
    int columnCount(const QModelIndex &parent = QModelIndex()) const
    {
        return 2;
    }
    QVariant data(const QModelIndex &index, int role) const
    {
        switch (role)
        {
        case Qt::DisplayRole:
        {
            return 4 - index.row() + index.column();
        }
        }
        return QVariant();
    }
};

int main(int argc, char *argv[])
{
    QApplication a(argc, argv);

    QTableView table;
    TestModel model;
    table.setModel(&model);
    table.setSortingEnabled(true);
    table.sortByColumn(0, Qt::AscendingOrder);
    table.reset();
    table.show();

    return a.exec();
}

The displayed widget

The problem is that the result is exactly the same when I use:

table.sortByColumn(0, Qt::AscendingOrder);

or

table.sortByColumn(0, Qt::DescendingOrder);

or

table.sortByColumn(1, Qt::AscendingOrder);

or

table.sortByColumn(1, Qt::DescendingOrder);

What am I doing wrong?

Answer

Tim Meyer picture Tim Meyer · Jul 23, 2012

QAbstractTableModel provides an empty sort() implementation.

Try doing

TestModel model;
QSortFilterProxyModel proxyModel;
proxyModel.setSourceModel( &model );
table.setModel( &proxyModel );