自定义QTableView右键弹出菜单, 并复制选中的单元格内容到剪贴板中

简介: 自定义QTableView右键弹出菜单, 并复制选中的单元格内容到剪贴板中

源码如下:


头文件

private:
    QAction *m_pActionCopy;
private slots:
    void copyData1();
    void copyData2();


源文件:

void frmDbDelegate::initTableView()
{
m_pActionCopy = new QAction(tr("复制"), ui->tableView);
    connect(m_pActionCopy, &QAction::triggered, this, &frmDbDelegate::copyData2);
    ui->tableView->setSelectionMode(QAbstractItemView::ContiguousSelection); //设置为连续选择模式
    ui->tableView->setContextMenuPolicy(Qt::ActionsContextMenu);             //设置为action菜单模式
    ui->tableView->addAction(this->m_pActionCopy);
}
//粘贴板表格内容格式:
//列与列之间内容以制表符分隔("\t")
//行与行之间内容以换行符分隔("\n")
//粘贴:
//获取粘贴板内容,把内容分解成单个item的值并放到表格中
//通过QApplication::clipboard()->text()类获取粘贴板的内容
//复制:
//获取选中item,把选中item内容组织一下并放到粘贴板
//通过QApplication::clipboard()->setText()设置粘贴板内容
void frmDbDelegate::copyData1()
{
    QModelIndexList indexes = ui->tableView->selectionModel()->selectedIndexes();
    if (indexes.count() == 0)
    {
        //select nothing
        return;
    }
    QMap<QString, QString> map;
    QModelIndex index;
    int k = 0;
    int maxCol = 0;
    int maxRow = 0;
    int minCol = 0;
    int minRow = 0;
    foreach (index, indexes)
    {
        int col = index.column();
        int row = index.row();
        if (k == 0)
        {
            minCol = col;
            minRow = row;
        }
        if (col > maxCol)
            maxCol = col;
        if (row > maxRow)
            maxRow = row;
        QString text = index.model()->data(index, Qt::EditRole).toString();
        map[QString::number(row) + "," + QString::number(col)] = text;
        k++;
    }
    QString rs = "";
    for (int row = minRow; row <= maxRow; row++)
    {
        for (int col = minCol; col <= maxCol; col++)
        {
            if (col != minCol)
                rs += "\t";
            rs += map[QString::number(row) + "," + QString::number(col)];
        }
    }
    rs += "\r\n";
    //复制到剪贴板
    QClipboard *board = QApplication::clipboard();
    board->setText(rs);
    qDebug() << rs;
}
void frmDbDelegate::copyData2()
{
    QStringList list;
    QModelIndexList indexes = ui->tableView->selectionModel()->selectedIndexes();
    if (indexes.count() == 0)
    {
        //select nothing
        return;
    }
    foreach (const QModelIndex &index, indexes)
    {
        list << index.data().toString();
    }
    QApplication::clipboard()->setText(list.join(","));
}




---


参考文献


《Qt QTableView 上加右键弹出菜单, 并复制选中的单元格内容到剪贴板中》


http://www.doczj.com/doc/c51cfb63cf84b9d528ea7a29.html


《已选中QTableView中的行/行复制到QClipboard》


http://cn.voidcc.com/question/p-myqnyjft-mk.html


《复制QTableView的一部分(Copying part of QTableView)》


https://www.it1352.com/549965.html


《QTableWidget, QTableView实现粘贴复制》


https://blog.csdn.net/time_forget/article/details/100765595


相关文章
|
存储 缓存 自然语言处理
QT基础教程(QMap和QHash)
QT基础教程(QMap和QHash)
1159 0
std::atomic和std::mutex区别
模板类std::atomic是C++11提供的原子操作类型,头文件 #include<atomic>。在多线程调用下,利用std::atomic可实现数据结构的无锁设计。
305 2
Qt6学习笔记五(自定义对话框、QMessageBox、QColorDialog、QFileDialog、QFontDialog)
Qt6学习笔记五(自定义对话框、QMessageBox、QColorDialog、QFileDialog、QFontDialog)
695 0
|
Oracle 关系型数据库 Linux
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
通过这一连串的步骤,可以专业且有效地在Linux下为Qt编译Oracle驱动库 `libqsqloci.so`,使得Qt应用能够通过OCI与Oracle数据库进行交互。这些步骤适用于具备一定Linux和Qt经验的开发者,并且能够为需要使用Qt开发数据库应用的专业人士提供指导。
522 1
讲解linux下的Qt如何编译oracle的驱动库libqsqloci.so
Qt在QTableWidget、View等表格中添加右击菜单
Qt在QTableWidget、View等表格中添加右击菜单
1275 0
|
网络协议 网络安全 API
Qt 网络编程之美:探索 URL、HTTP、服务发现与请求响应
Qt 网络编程之美:探索 URL、HTTP、服务发现与请求响应
1332 1
使用代码实现QT自定义布局
使用代码实现QT自定义布局
188 0
|
C++ 计算机视觉
Opencv(C++)系列学习---读取视频文件和打开摄像头
Opencv(C++)系列学习---读取视频文件和打开摄像头
721 0
《QT从基础到进阶·二十四》按钮组QButtonGroup,单选框QRadioButton和多选框QCheckBox
《QT从基础到进阶·二十四》按钮组QButtonGroup,单选框QRadioButton和多选框QCheckBox
923 0
|
数据安全/隐私保护
NPM 为自己创建的组织付费
NPM 为自己创建的组织付费