Михаиллл
Михаиллл17 июня 2020 г. 14:05

Можно ли в QTableView менять значения в столбце.

Добрый день.
У меня есть база, в табличке один из столбцов - дата в секундах типа "1564820737". Можноли в QTableView менять отображение или значение, другими словами менять "1564820737" на нужный формат даты и времени?

Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

6
Evgenii Legotckoi
  • 17 июня 2020 г. 14:19

Добрый день. Наследуйтесь от модели данных, которая отвечает за данную таблицу. Потом переопределите метод data, чтобы сконвертировать секунды в нужный формат. И возвращайте для этого столбца сконвертированное значение. QDateTime имеет метод для формата времени и даты.

    Михаиллл
    • 17 июня 2020 г. 14:45

    Я так попытался сделать, но почемуту отражает пустые ячейки. Скажите пожалуйста, где у меня могут не получаться данные? Таблица строиться в нужном размере, но с пустыми ячейками.
    .h

    #ifndef MYSQLMODEL_H
    #define MYSQLMODEL_H
    
    #include <QObject>
    #include <QSqlQueryModel>
    
    class MySqlModel: public QSqlQueryModel
    {
        Q_OBJECT
    public:
        explicit MySqlModel(QObject *parent = nullptr);
    
        enum Roles
        {
            timeRole1= Qt::UserRole+1,
            valueRole1,
            numberRole1
        };
    
        QVariant data(const QModelIndex & index, int role = Qt::DisplayRole) const;
        QVariantMap get(int idx) const;
    
    signals:
    
    protected:
        QHash<int,QByteArray> roleNames()const;
    
    public slots:
        void updateModel();
    };
    #endif // MYSQLMODEL_H
    
    

    .cpp

    #include "mysqlmodel.h"
    #include "QDebug"
    
    MySqlModel::MySqlModel(QObject *parent) : QSqlQueryModel (parent)
    {
        this->updateModel();
    }
    
    QVariant MySqlModel::data(const QModelIndex &index, int role) const
    {
        qDebug()<<index.column()<<index.row();
        int columnId = role - Qt::UserRole - 1;
        // Создаём индекс с помощью новоиспечённого ID колонки
        QModelIndex modelIndex = this->index(index.row(), columnId);
    
        /* И с помощью уже метода data() базового класса
         * вытаскиваем данные для таблицы из модели
         * */
        return QSqlQueryModel::data(modelIndex, Qt::DisplayRole);
    }
    
    QVariantMap MySqlModel::get(int idx) const
    {
        QVariantMap map;
        foreach(int k, roleNames().keys()) {
            map[roleNames().value(k)] = data(index(idx, 0), k);
        }
        return map;
    }
    
    QHash<int, QByteArray> MySqlModel::roleNames() const
    {
        QHash<int, QByteArray> roles;
        roles[timeRole1]="Time";
        roles[valueRole1]="Value";
        roles[numberRole1]="Number";
        return roles;
    }
    
    void MySqlModel::updateModel()
    {
        this->setQuery("SELECT Time, Value, Number FROM data12");
    }
    
    
    
    
      Михаиллл
      • 17 июня 2020 г. 14:51

      Похоже если так сделать, то наверно будет нормально, нужно только вспомнить, как галочки убрать в таблице

      QModelIndex modelIndex = this->index(index.row(), index.column());
      
        Михаиллл
        • 17 июня 2020 г. 15:04
        • (ред.)
        • Ответ был помечен как решение.

        Так работает

        #include "mysqlmodel.h"
        #include "QDebug"
        
        MySqlModel::MySqlModel(QObject *parent) : QSqlQueryModel (parent)
        {
            this->updateModel();
        }
        
        QVariant MySqlModel::data(const QModelIndex &index, int role) const
        {
            QModelIndex modelIndex = this->index(index.row(), index.column());
            if (role == Qt::DisplayRole)
            {
                if(modelIndex.column() != 0){
                    QVariant variant = QSqlQueryModel::data(modelIndex, Qt::DisplayRole);
                    return variant;
                }
                else {
                    QVariant time = QSqlQueryModel::data(modelIndex, Qt::DisplayRole);
                    QString dateTime = QDateTime::fromTime_t(time.toLongLong() ).toString("dd-MM-yyyy hh:mm:ss");
                    QVariant variant(dateTime);
                    //QVariant variant = QSqlQueryModel::data(modelIndex, Qt::DisplayRole);
                    return variant;
                }
            }
            return QVariant();
        }
        
        QVariantMap MySqlModel::get(int idx) const
        {
            QVariantMap map;
            foreach(int k, roleNames().keys()) {
                map[roleNames().value(k)] = data(index(idx, 0), k);
            }
            return map;
        }
        
        QVariant MySqlModel::headerData(int section, Qt::Orientation orientation, int role) const
        {
            if (orientation == Qt::Horizontal && role == Qt::DisplayRole)
            {
                switch (section)
                {
                case 0:
                    return "Время";
                case 1:
                    return "Значение";
                case 2:
                    return "Группа";
                default:
                    return QVariant();
                }
            }
            return QAbstractTableModel::headerData(section, orientation, role);
        }
        
        QHash<int, QByteArray> MySqlModel::roleNames() const
        {
            QHash<int, QByteArray> roles;
            roles[timeRole1]="Time";
            roles[valueRole1]="Value";
            roles[numberRole1]="Number";
            return roles;
        }
        
        void MySqlModel::updateModel()
        {
            this->setQuery("SELECT Time, Value, Number FROM data12");
        }
        
        
        
        
          ИП
          • 18 июня 2020 г. 1:34
          • (ред.)

          Можно попробовать заменить запрос
          SELECT Time, Value, Number FROM data12 на
          SELECT from_unixtime(Time, '%D-%Y-%M %H:%i:%s'), Value, Number FROM data12,

          а чтобы не менять заголовки в модели, можно сделать так:

          SELECT 
              from_unixtime(Time, '%D-%Y-%M %H:%i:%s') AS "Время", 
              Value AS "Значение", 
              Number AS "Группа" 
          FROM data12
          
            Evgenii Legotckoi
            • 18 июня 2020 г. 2:09
            • (ред.)

            Это вредный совет. Вы добавляете бессмысленную и беспощадную нагрузку на базу данных.
            В случае наличия 1000 клиентских машин на один сервер вы нагружаете сервер двумя тысячами бесполезных запросов, в то время как клиентская программа справится с подобным "за пару лишних тактов", условно говоря, и не подавится.

              Комментарии

              Только авторизованные пользователи могут публиковать комментарии.
              Пожалуйста, авторизуйтесь или зарегистрируйтесь
              AD

              C++ - Тест 004. Указатели, Массивы и Циклы

              • Результат:50баллов,
              • Очки рейтинга-4
              m
              • molni99
              • 26 октября 2024 г. 8:37

              C++ - Тест 004. Указатели, Массивы и Циклы

              • Результат:80баллов,
              • Очки рейтинга4
              m
              • molni99
              • 26 октября 2024 г. 8:29

              C++ - Тест 004. Указатели, Массивы и Циклы

              • Результат:20баллов,
              • Очки рейтинга-10
              Последние комментарии
              i
              innorwall14 ноября 2024 г. 19:42
              Как Копировать Файлы в Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
              i
              innorwall14 ноября 2024 г. 17:09
              Qt/C++ - Урок 068. Hello World с использованием системы сборки CMAKE в 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
              innorwall14 ноября 2024 г. 12:05
              EVILEG-CORE. Использование Google reCAPTCHA 2001; 98 29 34 priligy buy
              i
              innorwall14 ноября 2024 г. 12:00
              PyQt5 - Урок 007. Работаем с QML QtQuick (Сигналы и слоты) priligy 30mg Am J Obstet Gynecol 171 1488 505
              Сейчас обсуждают на форуме
              i
              innorwall14 ноября 2024 г. 11:39
              добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
              i
              innorwall11 ноября 2024 г. 18:55
              Всё ещё разбираюсь с кешем. 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
              9Anonim25 октября 2024 г. 16:10
              Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
              ИМ
              Игорь Максимов3 октября 2024 г. 11:05
              Реализация навигации по разделам Спасибо Евгений!

              Следите за нами в социальных сетях