QTableview多单元格的复制、粘贴。

文章目录


前言

QTableview多单元格的复制、粘贴。可以在word或者excel表格中复制后粘贴到tableview。我这里是直接在mainwindow里写的这个函数,规范来说应该继承QTableview后,在派生类中重新keyPressEvent函数。

关键代码

void MainWindow::keyPressEvent(QKeyEvent *keyEvent)
{
    if(keyEvent->matches(QKeySequence::Copy))//复制
    {
        QModelIndexList indexList = ui->tableView->selectionModel()->selectedIndexes();
        if(indexList.isEmpty())
            return;
        int startRow = indexList.first().row();
        int endRow = indexList.last().row();
        int startCol = indexList.first().column();
        int endCol = indexList.last().column();
        QStringList clipboardTextList;
        for(int i = startRow;i <= endRow;i++)
        {
            QStringList rowText;
            for(int j = startCol;j <= endCol;j++)
            {
                rowText.append(m_model.data(m_model.index(i,j)).toString());
            }
            clipboardTextList.append(rowText.join('\t'));
        }
        QString clipboardText = clipboardTextList.join('\n');
        QApplication::clipboard()->setText(clipboardText);
    }
    else if (keyEvent->matches(QKeySequence::Paste))
    {
        QString clipboardText = QApplication::clipboard()->text();
        if(clipboardText.isEmpty())
            return;
        QStringList rowTextList = clipboardText.split('\n');
        if(rowTextList.last().isEmpty())//从word或者excel复制的内容后面可能会带'\n',导致split出来后面有个空字符串。
            rowTextList.removeLast();
        QModelIndexList indexList = ui->tableView->selectionModel()->selectedIndexes();
        if(indexList.isEmpty())
            return;
        QModelIndex startIndex = indexList.first();
        for(int i = 0;i < rowTextList.size();i++)
        {
            QStringList itemTextList = rowTextList.at(i).split('\t');
            for(int j = 0;j < itemTextList.size();j++)
            {
                QModelIndex curIndex = m_model.index(i + startIndex.row(),j + startIndex.column());
                if(curIndex.isValid())
                {
                    m_model.setData(curIndex,itemTextList.at(j));
                }
            }
        }
    }
}
  • 2
    点赞
  • 15
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
QTableView实现粘贴复制可以通过以下步骤实现: 1. 选中需要复制单元,按下Ctrl+C进行复制。 2. 选中需要粘贴单元,按下Ctrl+V进行粘贴。 3. 如果需要自定义复制粘贴的操作,可以通过重写QTableView的keyPressEvent()函数来实现。例如,以下代码实现了在QTableView中按下Ctrl+C复制选中的单元,并在按下Ctrl+V时将剪贴板中的内容粘贴到选中的单元中: ```python from PyQt5.QtWidgets import QTableView, QAbstractItemView, QClipboard, QApplication from PyQt5.QtCore import Qt class MyTableView(QTableView): def __init__(self, parent=None): super().__init__(parent) self.setEditTriggers(QAbstractItemView.NoEditTriggers) # 禁止编辑 self.setContextMenuPolicy(Qt.CustomContextMenu) # 设置右键菜单策略 self.customContextMenuRequested.connect(self.showContextMenu) # 显示右键菜单 def keyPressEvent(self, event): if event.matches(QKeySequence.Copy): self.copy() elif event.matches(QKeySequence.Paste): self.paste() else: super().keyPressEvent(event) def copy(self): selection = self.selectionModel().selection() if selection: indexes = selection.indexes() if indexes: rows = sorted(index.row() for index in indexes) columns = sorted(index.column() for index in indexes) rowcount = rows[-1] - rows[0] + 1 colcount = columns[-1] - columns[0] + 1 table = [[''] * colcount for _ in range(rowcount)] for index in indexes: row = index.row() - rows[0] column = index.column() - columns[0] table[row][column] = index.data() text = '\n'.join('\t'.join(row) for row in table) QApplication.clipboard().setText(text) def paste(self): selection = self.selectionModel().selection() if selection: indexes = selection.indexes() if indexes: rows = sorted(index.row() for index in indexes) columns = sorted(index.column() for index in indexes) rowcount = rows[-1] - rows[0] + 1 colcount = columns[-1] - columns[0] + 1 text = QApplication.clipboard().text() table = [row.split('\t') for row in text.split('\n')] for row in range(min(rowcount, len(table))): for column in range(min(colcount, len(table[row]))): index = self.model().index(rows[0] + row, columns[0] + column) self.model().setData(index, table[row][column]) def showContextMenu(self, pos): menu = self.createStandardContextMenu() menu.exec_(self.viewport().mapToGlobal(pos)) ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值