QTableView怎么实现一行一行的输出显示

QTableView怎么实现一行一行的输出显示,第1张

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)

在excel中设置不允许更改表格高度和列宽,允许更改其中的内容先取消单元格锁定再设置保护工作表。

软件工具:Excel 2013

1、选中表格,右击选择设置单元格格式。

2、点击保护选项卡,把“锁定”取消掉,不要选中,然后点击确定。

3、点击审阅,然后功能区中点击“保护工作表”。

4、选中“选定未锁定的单元格”。这里是选择可以 *** 作的选项,下面插入、筛选等可按需要选择。然后点击确定。

5、这样就锁定了行列,无法修改行高列宽。右键菜单中的一些功能也变为灰色。

5、如果需要修改,再点击撤消保护工作表即可。

解决办法:

打开我的电脑—组织—文件夹搜索选项-—查看

去掉 “使用复选框以选择项”前面的对钩。

取消快捷方式上的小箭头。

用鼠标右键单击桌面空白处,从d出菜单中选择“属性”。在打开的“显示 属性”窗口中选择“外观”选项卡,点高级,点击“项目”中的下拉箭头,从中选择“图标”,这时旁边的“大小”选项由本来的灰色变为可用,其值为Windows的默认值“32”,将这个值改为“30”或者更小一些,但不要小于24,然后单击下面的“确定”按钮。

启动注册表编辑器,然后依次展开如下分支:“HKEY_CLASSES_ROOT\lnkfile”;


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11473398.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-16
下一篇 2023-05-16

发表评论

登录后才能评论

评论列表(0条)

保存