QTableView常用于实现数据的表格显示。下面我们如何按步骤实现学生信息表格:

一 添加表头

//准备数据模型
    QStandardItemModel *student_model = new QStandardItemModel();
    student_model->setHorizontalHeaderItem(0, new QStandardItem(QObject::tr("Name")));
    student_model->setHorizontalHeaderItem(1, new QStandardItem(QObject::tr("NO.")));
    student_model->setHorizontalHeaderItem(2, new QStandardItem(QObject::tr("Sex")));
    student_model->setHorizontalHeaderItem(3, new QStandardItem(QObject::tr("Age")));
    student_model->setHorizontalHeaderItem(4, new QStandardItem(QObject::tr("College")));
    //利用setModel()方法将数据模型与QTableView绑定
    ui->student_tableview->setModel(student_model);

二 设置表格属性

//设置列宽不可变动,即不能通过鼠标拖动增加列宽        
    ui->student_tableview->horizontalHeader()->setResizeMode(0, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(1, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(2, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(3, QHeaderView::Fixed);   
    ui->student_tableview->horizontalHeader()->setResizeMode(4, QHeaderView::Fixed);

//设置表格的各列的宽度值        
    ui->student_tableview->setColumnWidth(0,100);    
    ui->student_tableview->setColumnWidth(1,100);    
    ui->student_tableview->setColumnWidth(2,100);    
    ui->student_tableview->setColumnWidth(3,100);    
    ui->student_tableview->setColumnWidth(4,100);

//默认显示行头,如果你觉得不美观的话,我们可以将隐藏        
    ui->student_tableview->verticalHeader()->hide();

//设置选中时为整行选中        
    ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows);         
      
    //设置表格的单元为只读属性,即不能编辑        
    ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers);

//如果你用在QTableView中使用右键菜单,需启用该属性        
    ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu);

三 动态添加行

在表格中添加行时,我们只需要在model中插入数据即可,一旦model中的数据发生变化,QTabelView显示就会做相应的变动

//在第一行添加学生张三的个人信息(setItem函数的第一个参数表示行号,第二个表示列号,第三个为要显示的数据)
    student_model->setItem(0, 0, new QStandardItem(“张三"));
    student_model->setItem(0, 1, new QStandardItem("20120202"));
    student_model->setItem(0, 2, new QStandardItem("男"));
    student_model->setItem(0, 3, new QStandardItem("18"));
    student_model->setItem(0, 4, new QStandardItem("土木学院"));

四 设置数据显示的样式 

//设置单元格文本居中,张三的数据设置为居中显示
    student_model->item(0, 0)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 1)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 2)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 3)->setTextAlignment(Qt::AlignCenter);
    student_model->item(0, 4)->setTextAlignment(Qt::AlignCenter);

//设置单元格文本颜色,张三的数据设置为红色
    student_model->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0))); 
    student_model->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0))); 
    student_model->item(0, 2)->setForeground(QBrush(QColor(255, 0, 0))); 
    student_model->item(0, 3)->setForeground(QBrush(QColor(255, 0, 0))); 
    student_model->item(0, 4)->setForeground(QBrush(QColor(255, 0, 0)));

//将字体加粗
    student_model->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 2)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 3)->setFont( QFont( "Times", 10, QFont::Black ) );
    student_model->item(0, 4)->setFont( QFont( "Times", 10, QFont::Black ) );

//设置排序方式,按年龄降序显示
    student_model->sort(3, Qt::DescendingOrder);

Qt QStandardItemModel用法(超级详细)

QStandardItemModel 是标准的以项数据(item data)为基础的标准数据模型类,通常与 QTableView 组合成 Model/View 结构,实现通用的二维数据的管理功能。

本节介绍 QStandardltemModel 的使用,主要用到以下 3 个类:

  1. QStandardItemModel:基于项数据的标准数据模型,可以处理二维数据。维护一个二维的项数据数组,每个项是一个 QStandardltem 类的变量,用于存储项的数据、字体格式、对齐方式等。
  2. QTableView:二维数据表视图组件,有多个行和多个列,每个基本显示单元是一个单元格,通过 setModel() 函数设置一个 QStandardItemModel 类的数据模型之后,一个单元格显示 QStandardItemModel 数据模型中的一个项。
  3. QItemSelectionModel:一个用于跟踪视图组件的单元格选择状态的类,当在 QTableView 选择某个单元格,或多个单元格时,通过 QItemSelectionModel 可以获得选中的单元格的模型索引,为单元格的选择操作提供方便。

这几个类之间的关系是:QTableView 是界面视图组件,其关联的数据模型是 QStandardItem Model,关联的项选择模型是 QItemSelectionModel,QStandardItemModel 的数据管理的基本单元是 QStandardItem。

实例 samp5_3 演示 QStandardItemModel 的使用,其运行时界面如图 1 所示。


图 1 实例 samp5_3 的运行时界面

该实例具有如下功能:

  • 打开一个纯文本文件,该文件是规则的二维数据文件,通过字符串处理获取表头和各行各列的数据,导入到一个 QStandardItemModel 数据模型。
  • 编辑修改数据模型的数据,可以插入行、添加行、删除行,还可以在 QTableView 视图组件中直接修改单元格的数据内容。
  • 可以设置数据模型中某个项的不同角色的数据,包括文字对齐方式、字体是否粗体等。
  • 通过 QItemSelectionModel 获取视图组件上的当前单元格,以及选择单元格的范围,对选择的单元格进行操作。
  • 将数据模型的数据内容显示到 QPlainTextEdit 组件里,显示数据模型的内容,检验视图组件上做的修改是否与数据模型同步。
  • 将修改后的模型数据另存为一个文本文件。

界面设计与主窗口类定义

本实例的主窗口从 QMainWindow 继承而来,中间的 TableView 和 PlainTextEdit 组件采用水平分割条布局。在 Action 编辑器中创建如图 2 所示的一些 Action,并由 Action 创建主工具栏上的按钮,下方的状态栏设置了几个 QLabel 组件,显示当前文件名称、当前单元格行号、列号,以及相应内容。


图 2 实例中创建的 Action

主窗口类 MainWindow 里新增的定义如下(省略了 UI 设计器生成的界面组件的槽函数的声明):

  1. #define FixedColumnCount 6 //文件固定 6 列
  2. class MainWindow : public QMainWindow
  3. {
  4. Q_OBJECT private:
  5. QLabel *LabCurFile; //当前文件
  6. QLabel *LabCellPos; //当前单元格行列号
  7. QLabel *LabCellText; //当前单元格内容
  8. QStandardItemModel * theModel; //数据模型
  9. QItemSelectionModel *theSelection; //选择模型
  10. void iniModelFromStringList (QStringList&) ; //从 StringList 初始化数据模型
  11. public:
  12. explicit MainWindow(QWidget *parent = 0);
  13. private slots:
  14. //当前选择单元格发生变化
  15. void on_currentChanged(const QModelIndex &current, const QModelIndex &previous);
  16. private:
  17. Ui::MainWindow *ui;
  18. };

这里定义了数据模型变量 theModel,项数据选择模型变量 theSelection。

定义的私有函数 iniModelFromStringList() 用于在打开文件时,从一个 QStringList 变量的内容创建数据模型。

自定义槽函数 on_currentChanged() 用于在 TableView 上选择单元格发生变化时,更新状态栏的信息显示,这个槽函数将会与项选择模型 theSelection 的 currentChanged() 信号关联。

QStandardltemModel的使用

系统初始化

在 MainWindow 的构造函数中进行界面初始化,数据模型和选择模型的创建,以及与视图组件的关联,信号与槽的关联等设置,代码如下:

  1. MainWindow::MainWindow(QWidget *parent) : QMainWindow(parent), ui (new Ui::MainWindow)
  2. {
  3. ui->setupUi(this);
  4. setCentralWidget(ui->splitter);
  5. theModel = new QStandardltemModel (2, FixedColumnCount, this) ; //数据模型
  6. theSelection = new QItemSelectionModel (theModel) ;//选择模型
  7. connect(theSelection,SIGNAL(currentChanged(QModelIndex,QModelIndex)), this,SLOT(on_currentChanged(QModelIndex,QModelIndex)));
  8. ui->tableView->setModel (theModel) ; //设置数据模型
  9. ui->tableVi.evi-> setSelectionModel(theSelection) ; //设置选择模型
  10. ui->tableView->setSelectionMode(QAbstractItemView::ExtendedSelection);
  11. ui->tableView->setSelectionBehavior(QAbstractItemView::SelectItems);
  12. //创建状态栏组件,代码略
  13. }

在构造函数里首先创建数据模型 theModel,创建数据选择模型时需要传递一个数据模型变量作为其参数。这样,数据选择模型 theSelection 就与数据模型 theModel 关联,用于表示 theModel 的项数据选择操作。

创建数据模型和选择模型后,为 TableView 组件设置数据模型和选择模型:

ui->tableView->setModel (theModel) ; //设置数据模型
ui->tableView->setSelectionModel (theSelection) ; //设置选择模型

构造函数里还将自定义的槽函数 on_currentChanged() 与 theSelection 的 currentChanged() 信号关联,用于界面上 tableView 选择单元格发生变化时,显示单元格的行号、列号、内容等信息,槽函数代码如下:

  1. void MainWindow::on_currentChanged(const QModelIndex &current, const QModelIndex &previous)
  2. { //选择单元格变化时的响应
  3. if (current.isValid())
  4. {
  5. LabCellPos->setText (QString::asprintf ("当前单元格:%d 行,%d 列", current.row(),current.column()));
  6. QStandardItem* aItem=theModel->itemFromIndex(current);
  7. this->LabCellText->setText ("单元格内容:"+aItem->text());
  8. QFont font=aItem->font();
  9. ui->actFontBold->setChecked(font.bold());
  10. }
  11. }

从文本文件导入数据

QStandardItemModel 是标准的基于项数据的数据模型,以类似于二维数组的形式管理内部数据,适合于处理表格型数据,其显示一般采用 QTableView。

QStandardItemModel 的数据可以是程序生成的内存中的数据,也可以来源于文件。例如,在实际数据处理中,有些数据经常是以纯文本格式保存的,它们有固定的列数,每一列是一项数据,实际构成一个二维数据表。图 3 是本实例程序要打开的一个纯文本文件的内容,文件的第 1 行是数据列的文字标题,相当于数据表的表头,然后以行存储数据,以 TAB 键间隔每列数据。

当单击工具栏上的“打开文件”按钮时,需要选择一个这样的文件导入到数据模型,并在 tableView 上进行显示和编辑。图 3 的数据有 6 列,第 1 列是整数,第 2 至 4 列是浮点数,第 5 列是文字,第 6 列是逻辑型变量,“1”表示 true。


图 3 纯文本格式的数据文件

下面是“打开文件”按钮的槽函数代码:

  1. void MainWindow::on_actOpen_triggered()
  2. { //打开文件
  3. //QString str;
  4. QString curPath=QCoreApplication::applicationDirPath(); //获取应用程序的路径
  5. //调用打开文件对话框打开一个文件
  6. QString aFileName=QFileDialog::getOpenFileName(this,"打开一个文件",curPath, "井数据文件(*.txt);;所有文件(*.*)");
  7. if (aFileName.isEmpty())
  8. return; //如果未选择文件,退出
  9. QStringList fFileContent;//文件内容字符串列表
  10. QFile aFile(aFileName); //以文件方式读出
  11. if (aFile.open(QIODevice::ReadOnly | QIODevice::Text)) //以只读文本方式打开文件
  12. {
  13. QTextStream aStream(&aFile); //用文本流读取文件
  14. ui->plainTextEdit->clear();//清空
  15. while (!aStream.atEnd())
  16. {
  17. QString str=aStream.readLine();//读取文件的一行
  18. ui->plainTextEdit->appendPlainText(str); //添加到文本框显示
  19. fFileContent.append(str); //添加到 StringList
  20. }
  21. aFile.close();//关闭文件
  22. this->LabCurFile->setText("当前文件:"+aFileName);//状态栏显示
  23. ui->actAppend->setEnabled(true); //更新Actions的enable属性
  24. ui->actInsert->setEnabled(true);
  25. ui->actDelete->setEnabled(true);
  26. ui->actSave->setEnabled(true);
  27. iniModelFromStringList(fFileContent);//从StringList的内容初始化数据模型
  28. }
  29. }

这段代码让用户选择所需要打开的数据文本文件,然后用只读和文本格式打开文件,逐行读取其内容,将每行字符串显示到界面上的 plainTextEdit 里,并且添加到一个临时的 QStringList 类型的变量 fFileContent 里。

然后调用自定义函数 iniModelFromStringList(),用 fFileContent 的内容初始化数据模型。下面是 iniModelFromStringList() 函数的代码:

  1. void MainWindow::iniModelFromStringList(QStringList& aFileContent)
  2. { //从一个StringList 获取数据,初始化数据Model
  3. int rowCnt=aFileContent.count(); //文本行数,第1行是标题
  4. theModel->setRowCount(rowCnt-1); //实际数据行数
  5. //设置表头
  6. QString header=aFileContent.at(0);//第1行是表头
  7. //一个或多个空格、TAB等分隔符隔开的字符串, 分解为一个StringList
  8. QStringList headerList=header.split(QRegExp("\\s+"),QString::SkipEmptyParts);
  9. theModel->setHorizontalHeaderLabels(headerList); //设置表头文字
  10. //设置表格数据
  11. QString aText;
  12. QStringList tmpList;
  13. int j;
  14. QStandardItem *aItem;
  15. for (int i=1;i<rowCnt;i++)
  16. {
  17. QString aLineText=aFileContent.at(i); //获取数据区的一行
  18. //一个或多个空格、TAB等分隔符隔开的字符串, 分解为一个StringList
  19. QStringList tmpList=aLineText.split(QRegExp("\\s+"),QString::SkipEmptyParts);
  20. for (j=0;j<FixedColumnCount-1;j++) //tmpList的行数等于FixedColumnCount, 固定的
  21. { //不包含最后一列
  22. aItem=new QStandardItem(tmpList.at(j));//创建item
  23. theModel->setItem(i-1,j,aItem); //为模型的某个行列位置设置Item
  24. }
  25. aItem=new QStandardItem(headerList.at(j));//最后一列是Checkable,需要设置
  26. //aItem=new QStandardItem();//最后一列是Checkable,设置
  27. aItem->setCheckable(true); //设置为Checkable
  28. //aItem->setTextAlignment(Qt::AlignHCenter);
  29. if (tmpList.at(j)=="0")
  30. aItem->setCheckState(Qt::Unchecked); //根据数据设置check状态
  31. else
  32. aItem->setCheckState(Qt::Checked);
  33. theModel->setItem(i-1,j,aItem); //为模型的某个行列位置设置Item
  34. }
  35. }

传递来的参数 aFileContent 是文本文件所有行构成的 StringList,文件的每一行是 aFileContent 的一行字符串,第 1 行是表头文字,数据从第 2 行开始。

程序首先获取字符串列表的行数,然后设置数据模型的行数,因为数据模型的列数在初始化时己经设置了。

然后获取字符串列表的第 1 行,即表头文字,用 QString::split() 函数分割成一个 QStringList,设置为数据模型的表头标题。

QString::split() 函数根据某个特定的符号将字符串进行分割。例如,header 是数据列的标题, 每个标题之间通过一个或多个 TAB 键分隔,其内容是:

测深(m) 垂深(m) 方位(°) 总位移(m) 固井质量 测井取样

那么通过上面的 split() 函数操作,得到一个字符串列表 headerList,其内容是:

测深(m)
垂深(m)
方位(°)
总位移(m)
固井质量
测井取样

也就是分解为一个 6 行的 StringList。然后使用此字符串列表作为数据模型,设置表头标题的函数 setHorizontalHeaderLabels() 的参数,就可以为数据模型设置表头了。

同样,在逐行获取字符串后,也采用 split() 函数进行分解,为每个数据创建一个 QStandardltem 类型的项数据 altem,并赋给数据模型作为某行某列的项数据。

QStandardItemModel 以二维表格的形式保存项数据,每个项数据对应着 QTableView 的一个单元格。项数据不仅可以存储显示的文字,还可以存储其他角色的数据。

数据文件的最后一列是一个逻辑型数据,在 tableView 上显示时为其提供一个 CheckBox 组件,此功能通过调用 QStandardItem 的 setCheckable() 函数实现。

数据修改

当 TableView 设置为可编辑时,双击一个单元格可以修改其内容,对于使用 CheckBox 的列,改变 CheckBox 的勾选状态,就可以修改单元格关联项的选择状态。

在实例主窗口工具栏上有“添加行”、“插入行”、“删除行”按钮,它们实现相应的编辑操作,这些操作都是直接针对数据模型的,数据模型被修改后,会直接在 TableView 上显示出来。

添加行

“添加行”操作是在数据表的最后添加一行,其实现代码如下:

  1. void MainWindow::on_actAppend_triggered()
  2. { //在表格最后添加行
  3. QList<QStandardItem*> aItemList; //容器类
  4. QStandardItem *aItem;
  5. for(int i=0;i<FixedColumnCount-1;i++) //不包含最后1列
  6. {
  7. aItem=new QStandardItem("0"); //创建Item
  8. aItemList<<aItem; //添加到容器
  9. }
  10. //获取最后一列的表头文字
  11. QString str=theModel->headerData(theModel->columnCount()-1,Qt::Horizontal,Qt::DisplayRole).toString();
  12. aItem=new QStandardItem(str); //创建 "测井取样"Item
  13. aItem->setCheckable(true);
  14. aItemList<<aItem; //添加到容器
  15. theModel->insertRow(theModel->rowCount(),aItemList); //插入一行,需要每个Cell的Item
  16. QModelIndex curIndex=theModel->index(theModel->rowCount()-1,0);//创建最后一行的ModelIndex
  17. theSelection->clearSelection();//清空选择项
  18. theSelection->setCurrentIndex(curIndex,QItemSelectionModel::Select);//设置刚插入的行为当前选择行
  19. }

使用 QStandardltemModel::insertRow() 函数插入一行,其函数原型是:

void insertRow(int row, const QList<QStandardltem *> fiitems)

其中,row 是一个行号,表示在此行号之前插入一行,若 row 等于或大于总行数,则在最后添加一行。QList<QStandardItem *>&items 是一个 QStandardltem 类型的列表类,需要为插入的一行的每个项数据创建一个 QStandardltem 类型的项,然后传递给 insertRow() 函数。

在这段程序中,为前 5 列创建 QStandardItem 对象时,都使用文字“0”,最后一列使用表头的标题,并设置为 Checkable。创建完每个项数据对象后,使用 insertRow() 函数在最后添加一行。

插入行

“插入行”按钮的功能是在当前行的前面插入一行,实现代码与“添加行”类似。

删除行

“删除行”按钮的功能是删除当前行,首先从选择模型中获取当前单元格的模型索引,然后从模型索引中获取行号,调用 removeRow(int row) 删除指定的行。

  1. void MainWindow::on_actDelete_triggered()
  2. { //删除行
  3. QModelIndex curIndex=theSelection->currentIndex () ;//获取模型索引
  4. if (curIndex. row () ==theModel->rowCount () -1) //最后一行
  5. theModel->removeRow (curIndex.row () ) ; //删除最后一行
  6. else {
  7. theModel->removeRow (curIndex.row () );//删除一行,并重新设置当前选择行
  8. theSelection->setCurrentIndex (curIndex, QItemSelectionModel::Select);
  9. }
  10. }

单元格格式设置

工具栏上有 3 个设置单元格文字对齐方式的按钮,还有一个设置字体粗体的按钮。当在 TableView 中选择多个单元格时,可以同时设置多个单元格的格式。例如,“居左”按钮的代码如下:

  1. void MainWindow::on_actAlignLeft_triggered()
  2. { //设置文字居左对齐
  3. if (!theSelection->hasSelection())
  4. return;
  5. //获取选择的单元格的模型索引列表,可以是多选
  6. QModelIndexList selectedIndex=theSelection->selectedIndexes();
  7. for (int i=0;i<selectedIndex.count();i++)
  8. {
  9. QModelIndex aIndex=selectedIndex.at (i) ; //获取一个模型索引
  10. QStandardItem* aItem=theModel->itemFromIndex(aIndex);
  11. aItem->setTextAlignment (Qt::AlignLeft) ;//设置文字对齐方式
  12. }
  13. }

QItemSelectionModel::selectedIndexes() 函数返回选择单元格的模型索引列表,然后通过此列表获取每个选择的单元格的模型索引,再通过模型索引获取其项数据,然后调用 QStandardItem::setTextAlignment() 设置一个项的对齐方式即可。

“居中”和“居右”按钮的代码与此类似。

“粗体”按钮设置单元格的字体是否为粗体,在选择单元格时,actFontBold 的 check 状态根据当前单元格的字体是否为粗体自动更新。actFontBold 的 triggered(bool) 的槽函数代码如下,与设置对齐方式的代码操作方式类似:

  1. void MainWindow::on_actFontBold_triggered(bool checked)
  2. {//设置字体粗体
  3. if (!theSelection->hasSelection())
  4. return;
  5. //获取选择单元格的模型索引列表
  6. QModelIndexList selectedIndex=theSelection->selectedIndexes();
  7. for (int i=0;i<selectedIndex.count();i++)
  8. {
  9. QModelIndex aIndex=selectedIndex.at(i); //获取一个模型索引
  10. QStandardItem* aItem=theModel->itemFromIndex(aIndex);//获取项数据
  11. QFont font=aItem->font(); //获取字体
  12. font.setBold(checked); //设置字体是否粗体
  13. aItem->setFont(font); //重新设置字体
  14. }
  15. }

数据另存为文件

在视图组件上对数据的修改都会自动更新到数据模型里,单击工具栏上的“模型数据预览” 按钮,可以将数据模型的数据内容显示到 PlainTextEdit 里。

数据模型里的数据是在内存中的,工具栏上的“另存文件”按钮可以将数据模型的数据另存 为一个数据文本文件,同时也显示在 PlainTextEdit 里,其实现代码如下:

清理数据

    model_->removeRows(0,model_->rowCount());

这样清理数据,就不会影响到表格头部的数据了。

  1. void MainWindow::on_actSave_triggered()
  2. { //保存为文件
  3. QString curPath=QCoreApplication::applicationDirPath(); //获取应用程序的路径
  4. //调用打开文件对话框选择一个文件
  5. QString aFileName=QFileDialog::getSaveFileName(this,tr("选择一个文件"),curPath,
  6. "井斜数据文件(*.txt);;所有文件(*.*)");
  7. if (aFileName.isEmpty()) //未选择文件,退出
  8. return;
  9. QFile aFile(aFileName);
  10. if (!(aFile.open(QIODevice::ReadWrite | QIODevice::Text | QIODevice::Truncate)))
  11. return; //以读写、覆盖原有内容方式打开文件
  12. QTextStream aStream(&aFile); //用文本流读取文件
  13. QStandardItem *aItem;
  14. int i,j;
  15. QString str;
  16. ui->plainTextEdit->clear();
  17. //获取表头文字
  18. for (i=0;i<theModel->columnCount();i++)
  19. {
  20. aItem=theModel->horizontalHeaderItem(i); //获取表头的项数据
  21. str=str+aItem->text()+"\t\t"; //以TAB见隔开
  22. }
  23. aStream<<str<<"\n"; //文件里需要加入换行符 \n
  24. ui->plainTextEdit->appendPlainText(str);
  25. //获取数据区文字
  26. for ( i=0;i<theModel->rowCount();i++)
  27. {
  28. str="";
  29. for( j=0;j<theModel->columnCount()-1;j++)
  30. {
  31. aItem=theModel->item(i,j);
  32. str=str+aItem->text()+QString::asprintf("\t\t");
  33. }
  34. aItem=theModel->item(i,j); //最后一列是逻辑型
  35. if (aItem->checkState()==Qt::Checked)
  36. str=str+"1";
  37. else
  38. str=str+"0";
  39. ui->plainTextEdit->appendPlainText(str);
  40. aStream<<str<<"\n";
  41. }
  42. }
  43. 删除QWidget中的控件和清空QTableView表格内容用法

  44. 本文主要总结删除QWidget中的控件和清空QTableView表格内容用法,下面将详细讲述这两种用法的实现方式。

    1.1删除QWidget中的控件(函数removeWidget())

    要删除QWidget中的控件,可以现在QWidget用QVBoxLayout布局,然后用QVBoxLayout::removeWidget(QWidget*)函数删除指定名称的控件,删除后要用delete释放空间,否则不会显示出来。

            QVBoxLayout *m_VBoxLayout = new QVBoxLayout(this);
            QPushButton *m_button = QPushButton(QStringLiteral("按钮"));
            m_VBoxLayout->addWidget(m_button);
            if(!m_VBoxLayout->isEmpty())                         //如果垂直布局器中有控件,则执行删除控件
            {
                m_VBoxLayout->removeWidget(m_button);           //删除按钮控件
                delete m_button;                                //释放控件
                qDebug()<<m_VBoxLayout->isEmpty();              //判断垂直布局是否为空
            }

    1.2清空表格控件QTableView(函数clear())

    要清空表格控件QTableView,只需要清空模型项QStandItemModel的对象就行。只要用到函数QStandItemModel::clear()就可以了。下面代码是一个清空QTabView表格的简单用法。

        //初始化
        QTableView m_TableView = new QTableView;
        QStandardItemModel *m_StandItemModel = new QStandardItemModel;
        m_TableView.setModel(m_StandItemModel);
        m_StandItemModel->clear();          //清空模型时,对应表格的内容会同步清空

    1.3清空QTabView表格用法同样适用于列表控件QListView、树形控件QTreeView。

    总结:

    需要清空QWidget布局管理器中的控件,只需要用到函数QVBoxLayout::removeWidget(QWidget*)。

    要清空表格控件QTableView的内容,只需要用到函数QStandItemModel::clear()。

    Qt QTableView 如何清理列表里的数据

  45. 数据初始化

        tableView_ = new QTableView();model_ = new QStandardItemModel();tableView_->setModel(model_);// model 初始化model_->setColumnCount(6);model_->setHeaderData(0, Qt::Horizontal, tr("序号"));model_->setHeaderData(1, Qt::Horizontal, tr("审核编号"));model_->setHeaderData(2, Qt::Horizontal, tr("审核状态"));model_->setHeaderData(3, Qt::Horizontal, tr("含交易数"));model_->setHeaderData(4, Qt::Horizontal, tr("txid"));model_->setHeaderData(5, Qt::Horizontal, tr("操作"));// tableview 初始化tableView_->setSelectionBehavior(QAbstractItemView::SelectRows); // 选中整行tableView_->setSelectionMode(QAbstractItemView::SelectionMode::SingleSelection); // 只能单选tableView_->setEditTriggers(QTableView::EditTrigger::NoEditTriggers);tableView_->setAlternatingRowColors(true);tableView_->setColumnWidth(0, 100);tableView_->setColumnWidth(2, 80);tableView_->setColumnWidth(5, 130);tableView_->horizontalHeader()->setSectionResizeMode(0,QHeaderView::Interactive);tableView_->horizontalHeader()->setSectionResizeMode(1,QHeaderView::Stretch);tableView_->horizontalHeader()->setSectionResizeMode(4,QHeaderView::Stretch);#ifdef QT_DEBUGfor(int i = 0; i < 10; ++i) {QStandardItem *item = new QStandardItem();item->setCheckable(true);item->setText(QString::number(i));item->setCheckState(Qt::Unchecked);model_->setItem(i, 0, item);model_->setItem(i, 1, new QStandardItem("654654654"));model_->setItem(i, 2, new QStandardItem("admin"));model_->setItem(i, 3, new QStandardItem("admin"));model_->setItem(i, 4, new QStandardItem("admin"));model_->setItem(i, 5, new QStandardItem("admin"));}
    #elseonNextPage(0);
    #endif

qt中Qtableview的用法相关推荐

  1. (二)Qt中QTableView中加入Check列实现

    QTableView中嵌入复选框CheckBox        第二种方法:设置QAbstractTableModel的flags()函数法 通过Delegate创建QCheckBox来实现的Chec ...

  2. QT中QTableView 点击表头进行排序

    今日,由于工作需要,要实现在QTableView中点击表头进行排序的功能,但QTableView中并未提供此功能,经过苦苦的网络搜索也为发现可用的代码.最后经过跟踪QTableWidget的排序功能实 ...

  3. Qt中QMessageBox的用法---看这一篇就够了

    一.详细说明 QMessageBox类提供一个模态对话框,用于通知用户或询问用户一个问题并接收答案. 消息框显示一个主要文本,用于向用户提示某个情况;显示一个信息文本,用于进一步解释警报或向用户询问问 ...

  4. QT中的setAttribute()用法

    https://blog.csdn.net/qq_27312943/article/details/50899866 模态对话框就是指在子对话框弹出时,焦点被强行集中于该子对话框,子对话框不关闭,用户 ...

  5. QT 中 QCustomplot的用法

    主要介绍其用法 https://wendy.blog.csdn.net/category_11305276_2.html 官网:Qt Plotting Widget QCustomPlot - Dow ...

  6. QT中.arg的用法

    QString中的arg方法类似于"C中的printf中使用的格式输出符"和"C++中string的append方法"的结合体. 常用的两种格式如下: 1.用于 ...

  7. QT中QString的所有类用法大全

    前言 之前用到QT中QString的用法,但总是忘记,这次自己整理出来,自己想用可以随时查看,同时也可以帮助到大家. 文章目录 前言 一.QString与其他变量的转换 1.QString::numb ...

  8. QT 中QTimer 和 startTimer()的区别

    最需要注意一点 请注意,QTimer的准确性取决于底层操作系统和硬件.timerType参数允许您自定义计时器的准确性.有关不同计时器类型的信息,请参见Qt::TimerType.大多数平台支持20毫 ...

  9. Qt:QTableView(01) 的用法

    Qt:QTableView(01) 的用法 文章目录 Qt:QTableView(01) 的用法 前言 一 .给 QTableView 添加表头 二.设置表格属性 1. 设置 QTableView 内 ...

最新文章

  1. valgrind——hisi平台valgrind
  2. Metasploit攻击Oracle的环境搭建
  3. Android 判断屏幕方向一个大坑
  4. (转载)聊聊Git原理
  5. 手机中的AR是怎么实现的
  6. Intel Realsense D435 Post-processing filters 后处理过滤器(用于消除图像的黑洞)
  7. mysql不能正常yum remove怎么办?--noscripts
  8. php算法求出兔子数列,PHP算法:斐波那契数列的N种算法
  9. java中求5的阶乘
  10. 【会议】2009-11-13
  11. android:autolink 颜色,Android设置完autoLink属性后自定义跳转到指定界面
  12. rockycapture_RockyCapture航线规划软件介绍文档
  13. C#接口的使用场合,接口应用
  14. 批处理结束某个进程_[MIT6.824-lab1] 批处理算法模型MapReduce
  15. 190628每日一句
  16. paip.c++ 正则表达式的应用跟普通正则表达式的区别以及特别注意点总
  17. Qt5 与OpenCV4教程一:Qt5.12安装与OpenCV4.5.0配置
  18. Eclipse中的Lua插件 LDT
  19. ios设备如何安装chatgpt
  20. 如何快速去除抖音短视频水印

热门文章

  1. python 读取文件_python读取docx文件,就是如此简单
  2. linux卸载anaconda_Win10安装Anaconda和Pytorch(CPU版)
  3. 某一个接口403 其他接口可以调通_设计模式HR:不会设计模式,你来面什么试?你以为设计模式只有23种?(真正的入门到精通可以用到入土)...
  4. java jdbc连接derby,通过JDBC连接到Derby数据库失败
  5. 正则表达式给html添加属性,正则表达式替换html元素属性的方法
  6. oracle 加全文索引,oracle全文索引的创建和使用
  7. wumpus java_人工智能经典问题The Wumpus World-简明窗体小游戏
  8. mysql卸载安装视频_MYSQL安装与卸载(一)
  9. c++ printf怎么用_【经典】把脉printf中的C进阶技巧
  10. java hh mm ss_【Java基础】比较时间大小(以HH:mm:ss格式为例)