Qt常用控件之表格QTableWidget

表格QTableWidget

QTableWidget 是一个表格控件,行和列交汇形成的每个单元格,是一个 QTableWidgetItem 对象。

1. QTableWidget属性

QTableWidget 的属性只有两个:

属性 说明
rowCount 当前行的个数。
columnCount 当前列的个数。

2. QTableWidget信号

信号 说明
cellClicked(int row, int column) 点击单元格时触发。
cellDoubleClicked(int row, int column) 双击单元格时触发。
cellEntered(int row, int column) 鼠标进入单元格时触发。
currentCellChanged(int row, int column,int previousRow, int previousColumn) 选中不同单元格时触发。

3. QTableWidget方法

方法 说明
item(int row, int column) 根据行数列数获取单元格的 QTableWidgetItem*
setItem(int row, int column, QTableWidgetItem*) 根据行数列数设置单元格中的元素。
currentItem() 返回被选中的元素 QTableWidgetItem*
currentRow() 返回被选中的是第几行。
currentColumn() 返回被选中的是第几列。
row(QTableWidgetItem*) 获取指定 item 是第几行。
column(QTableWidgetItem*) 获取指定 item 是第几列。
rowCount() 获取行数。
columnCount() 获取列数。
insertRow(int row) 在第 row 行处插入新行(新行变为第 row 行)。
insertColumn(int column) 在第 column 列插入新列(新列变为第 column 列)。
removeRow(int row) 删除第 row 行。
removeColumn(int column) 删除第 column 列。
setHorizontalHeaderItem(int column, QTableWidget*) 设置指定列的表头。
setVerticalHeaderItem(int row, QTableWidget*) 设置指定行的表头。

4. QTableWidgetItem方法

方法 说明
row() 获取当前是第几行。
column() 获取当前是第几列。
setText(const QString&) 设置文本。
setTextAlignment(int) 设置文本对齐。
setIcon(const QIcon&) 设置图标。
setSelected(bool) 设置能否被选中。
setSizeHints(const QSize&) 设置尺寸。
setFont(const QFont&) 设置字体。

5. 使用QTableWidget制作一个表格编辑器

表格编辑器的大部分功能 Qt 都已经提供了,我们只需要制作几个添加行首、列首之类的接口即可:

cpp 复制代码
#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    ui->lineEdit->setPlaceholderText("输入新增的列名");
}

Widget::~Widget()
{
    delete ui;
}

void Widget::on_pushButton_addRow_clicked()
{
    int row =ui->tableWidget->rowCount();
      ui->tableWidget->insertRow(row);
}


void Widget::on_pushButton_addColumn_clicked()
{
    QString content=ui->lineEdit->text();
    if(content.isEmpty())
    {
        return;
    }
    int column =ui->tableWidget->columnCount();
    ui->tableWidget->insertColumn(column);
    ui->tableWidget->setHorizontalHeaderItem(column,new QTableWidgetItem(content));

}

void Widget::on_pushButton_deleteRow_clicked()
{
    int curRow=ui->tableWidget->currentRow();
    ui->tableWidget->removeRow(curRow);
}

void Widget::on_pushButton_deleteColumn_clicked()
{
    int curColumn=ui->tableWidget->currentColumn();
    ui->tableWidget->removeremoveColumn(curColumn);
}
相关推荐
榴莲CC1 分钟前
抗干扰LED数显屏驱动VK1624 数码管显示芯片 3线串行接口
前端
半夏知半秋5 分钟前
kcp学习-skynet中的kcp绑定
开发语言·笔记·后端·学习
Tigger8 分钟前
用 Vue 3 做了一套年会抽奖工具,顺便踩了些坑
前端·javascript·vue.js
天天扭码12 分钟前
一文搞懂——React 19到底更新了什么
前端·react.js·前端框架
扶苏-su13 分钟前
Java--标准输入输出流
java·开发语言
玖釉-13 分钟前
[Vulkan 学习之路] 02 - 万物起源:创建 Vulkan 实例 (Instance)
c++·windows·图形渲染
weixin_4624462317 分钟前
【原创】使用langchain与MCP 与 Chrome DevTools 打造可调用浏览器工具的 Chat Agent
前端·langchain·chrome devtools
OpenTiny社区26 分钟前
OpenTiny 2025年度贡献者榜单正式公布~
前端·javascript·vue.js
OEC小胖胖31 分钟前
08|Commit 阶段:副作用如何被组织、执行与约束
前端·react.js·前端框架·react·开源库
奋斗的小青年!!38 分钟前
Flutter跨平台开发OpenHarmony应用:个人中心实现
开发语言·前端·flutter·harmonyos·鸿蒙