Skip to content
  • Categories
  • Recent
  • Tags
  • Popular
  • Users
  • Groups
  • Search
  • Get Qt Extensions
  • Unsolved
Collapse
Brand Logo
  1. Home
  2. Qt Development
  3. General and Desktop
  4. How to Change QTableView Item Text?

How to Change QTableView Item Text?

Scheduled Pinned Locked Moved Unsolved General and Desktop
3 Posts 3 Posters 1.7k Views 1 Watching
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • Taz742T Offline
    Taz742T Offline
    Taz742
    wrote on last edited by Taz742
    #1

    Hello all.
    I Have QTableView.
    I have the information QDatabase.

    if(globalall->db.open())
    {
        QSqlQueryModel* users = new QSqlQueryModel();
    
        QSqlQuery* query = new QSqlQuery();
    
        query->prepare("SELECT * FROM valuta");
    
        query->exec();
    
        users->setQuery(*query);
    
        ui->ValutaName->setModel(users);
        ui->ValutaName->verticalHeader()->hide();
        ui->ValutaName->horizontalHeader()->hide();
    
        globalall->db.close();
    }
    

    I want to change the text on DoubleClicked When index = (0,0) || (0,1) || (0,2).

    It Is Posibly?

    Do what you want.

    mrjjM 1 Reply Last reply
    0
    • Taz742T Taz742

      Hello all.
      I Have QTableView.
      I have the information QDatabase.

      if(globalall->db.open())
      {
          QSqlQueryModel* users = new QSqlQueryModel();
      
          QSqlQuery* query = new QSqlQuery();
      
          query->prepare("SELECT * FROM valuta");
      
          query->exec();
      
          users->setQuery(*query);
      
          ui->ValutaName->setModel(users);
          ui->ValutaName->verticalHeader()->hide();
          ui->ValutaName->horizontalHeader()->hide();
      
          globalall->db.close();
      }
      

      I want to change the text on DoubleClicked When index = (0,0) || (0,1) || (0,2).

      It Is Posibly?

      mrjjM Offline
      mrjjM Offline
      mrjj
      Lifetime Qt Champion
      wrote on last edited by mrjj
      #2

      @Taz742 said in How to Change QTableView Item Text?:

      QSqlQueryModel

      Hi
      QSqlQueryModel is readonly
      http://doc.qt.io/qt-5/qsqlquerymodel.html

      So i think you should use other model to allow editing.

      This is one sample
      http://doc.qt.io/qt-5/qtwidgets-itemviews-editabletreemodel-example.html

      1 Reply Last reply
      2
      • VRoninV Offline
        VRoninV Offline
        VRonin
        wrote on last edited by VRonin
        #3

        Welcome to the memory leak festival!!

        As @mrjj correctly pointed out:

        QSqlQueryModel is readonly

        if(globalall->db.open())
        {
            QStandardItemModel* users = new QStandardItemModel(this);
            QSqlQuery query;
            query.prepare("SELECT * FROM valuta");
        int fieldCount=0;
        if(query.exec()){
        for(bool firstRow=true;query.next();){
        const QSqlRecord currRecord=query.record();
        if(firstRow){
        fieldCount=currRecord.count();
        firstRow=false;
        users->insertColumns(0,fieldCount);
        for(int i=0;i<fieldCount;++i)
        users->setHeaderData(i,Qt::Horizontal,currRecord.fieldName(i));
        }
        const int newRow=users->rowCount();
        users->insertRow(newRow);
        for(int i=0;i<fieldCount;++i)
        users->setData(users->index(newRow,i),currRecord.value(i));
        }
        }
            ui->ValutaName->setModel(users);
            ui->ValutaName->verticalHeader()->hide();
            ui->ValutaName->horizontalHeader()->hide();
        
            globalall->db.close();
        }
        

        I want to change the text on DoubleClicked When index = (0,0) || (0,1) || (0,2).

        If you want only certain cells/rows/columns to be editable you'll need a proxy model in between, something like http://pastebin.com/ttF5amvC (or use QStandardItem::setFlags but I refuse on poorly justifiable moral grounds)

        "La mort n'est rien, mais vivre vaincu et sans gloire, c'est mourir tous les jours"
        ~Napoleon Bonaparte

        On a crusade to banish setIndexWidget() from the holy land of Qt

        1 Reply Last reply
        3

        • Login

        • Login or register to search.
        • First post
          Last post
        0
        • Categories
        • Recent
        • Tags
        • Popular
        • Users
        • Groups
        • Search
        • Get Qt Extensions
        • Unsolved