Сортировка файлов и папок в QSortFilterProxyModel

sort, QSortFilterProxyModel, qt

Доброго дня! Есть задача отсортировать данные в директории таким образом, чтобы сначала шли папки в алфавитном порядке, а затем файлы тоже в алфавитном порядке. Данным кодом получается добиться только порядка: сначала папки, потом файлы, но они не по алфавиту идут. Что в этом коде надо поправить, может кто видит..

bool SortFilterProxyModel::lessThan(const QModelIndex &left, const QModelIndex &right) const
{
    bool isDir = QVariant(sourceModel()->data(left, Roles::IsDirRole).toString()).toBool();

    QString const leftName  = sourceModel()->data(left,  Roles::NameRole).toString();
    QString const rightName = sourceModel()->data(right, Roles::NameRole).toString();

    if(isDir)
    {
        return true;
    }
    else
    {
        int const compare = QString::localeAwareCompare(leftName, rightName);
        if(compare != 0) {
            return compare < 0 && isDir;
        }
    }

    return false;
}
We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

6
Evgenii Legotckoi
  • July 29, 2020, 6:59 a.m.
  • (edited)

Добрый день! А какую исходную модель используете? Случайно не QDirModel ? Просто у неё есть метод setSorting , который при установке некоторых флагов позволит отсортировать как по имени, так и по типу, сначала директории, а потом файлы и наоборот. И использование QSortFilterProxyModel будет избыточна. Просто в Qt для подобного функционала уже всё реализовано.

    Вообще исходной является QAbstractTableModel. Само отображение происходит в QML. Изначально, когда это делалось про сортировку никто видимо не подумал, поэтому потом пришлось навернуть еще QSortFilterProxyModel поверх..
    Отображение в QML:

    model: SortFilterProxyModel {
                        source: FileBrowserModel
                        sortOrder: Qt.AscendingOrder
                        sortCaseSensitivity: Qt.CaseInsensitive                    
                    }
    

    Видимо в методе lessThan() сортировать по типу и имени не получится, это ей несколько проходов сделать надо будет.. либо какое-то хитрое условие прописать как сравнивать..

      Evgenii Legotckoi
      • July 29, 2020, 8:06 a.m.
      • (edited)

      Ну тогда так попробуйте. Там нужно делать сравнение по алфавиту лишь в том случае если и левый и правый индекс либо каталоги, либо файлы. Что по сути не делается в вашем коде.

      bool SortFilterProxyModel::lessThan(const QModelIndex &left, const QModelIndex &right) const
      {
          bool isLeftDir = QVariant(sourceModel()->data(left, Roles::IsDirRole).toString()).toBool();
          bool isRightDir = QVariant(sourceModel()->data(right, Roles::IsDirRole).toString()).toBool();
      
          QString const leftName  = sourceModel()->data(left,  Roles::NameRole).toString();
          QString const rightName = sourceModel()->data(right, Roles::NameRole).toString();
      
          if ((isLeftDir && isRightDir) || (!isLeftDir && !isRightDir))
          {
              const int compare = QString::localeAwareCompare(leftName, rightName);
              if(compare != 0) {
                  return compare < 0;
              }
          }
          else if (isLeftDir)
          {
              return true;
          }
      
          return false;
      }
      

        Шикарно! Спасибо, то что надо!
        Первый if понятен, а зачем вот эта часть, что-то не пойму..

        else if (isLeftDir)
            {
                return true;
            }
        

          Вам нужно расположить сначала каталоги, а потом файлы. Так же? Поэтому нужно проверить, что левый индекс является каталогом, а правый в данном случае будет считаться файлом, поскольку первый if уже исключил, что оба индекса могут отвечать за каталоги или файлы одновременнов.

            Ясно, спасибо. Работает как нужно

              Comments

              Only authorized users can post comments.
              Please, Log in or Sign up
              AD

              C ++ - Test 004. Pointers, Arrays and Loops

              • Result:50points,
              • Rating points-4
              m

              C ++ - Test 004. Pointers, Arrays and Loops

              • Result:80points,
              • Rating points4
              m

              C ++ - Test 004. Pointers, Arrays and Loops

              • Result:20points,
              • Rating points-10
              Last comments
              i
              innorwallNov. 14, 2024, 12:07 p.m.
              Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
              i
              innorwallNov. 14, 2024, 11:42 a.m.
              How to Copy Files in Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
              i
              innorwallNov. 14, 2024, 9:09 a.m.
              Qt/C++ - Tutorial 068. Hello World using the CMAKE build system in CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
              i
              innorwallNov. 14, 2024, 4:05 a.m.
              EVILEG-CORE. Using Google reCAPTCHA 2001; 98 29 34 priligy buy
              i
              innorwallNov. 14, 2024, 4 a.m.
              PyQt5 - Lesson 007. Works with QML QtQuick (Signals and slots) priligy 30mg Am J Obstet Gynecol 171 1488 505
              Now discuss on the forum
              i
              innorwallNov. 14, 2024, 3:39 a.m.
              добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
              i
              innorwallNov. 11, 2024, 10:55 a.m.
              Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
              9
              9AnonimOct. 25, 2024, 9:10 a.m.
              Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

              Follow us in social networks