一 添加表头
//准备数据模型
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”;
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)