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);
}
相关推荐
im_AMBER17 分钟前
React 01
前端·javascript·笔记·react.js·前端框架·web
@大迁世界23 分钟前
React 19.2.0 有哪些新变化
前端·javascript·react.js·前端框架·ecmascript
纵有疾風起37 分钟前
C++模版:模板初阶及STL简介
开发语言·c++·经验分享·开源
QT 小鲜肉42 分钟前
【个人成长笔记】Qt Creator快捷键终极指南:从入门到精通
开发语言·c++·笔记·qt·学习·学习方法
子豪-中国机器人44 分钟前
《C++ STL 基础入门》教案
java·开发语言
消失的旧时光-19431 小时前
ScheduledExecutorService
android·java·开发语言
勇闯逆流河1 小时前
【C++】用红黑树封装map与set
java·开发语言·数据结构·c++
实心儿儿1 小时前
C++——内存管理
c++
山,离天三尺三1 小时前
深度拷贝详解
开发语言·c++·算法
华仔啊1 小时前
用 Vue3 + Canvas 做了个超实用的水印工具,同事都在抢着用
前端·vue.js·canvas