从QTableView中导出数据到excel(二)

本文介绍了一种利用数据流快速将QTableView中的数据导出到Excel文件的方法,以实现高效的数据导出操作。
摘要由CSDN通过智能技术生成

用数据流导出数据,速度很快。

void HistoricalData::on_pbnExportData_clicked()
{
    QString filepath = QFileDialog::getSaveFileName(this, tr("Save as..."),
                                                  QString(), tr("EXCEL files (*.xls);;HTML-Files (*.txt);;"));

    if (filepath != "")
    {
        int row = ui->tableView->model()->rowCount();
        int col = ui->tableView->model()->columnCount();
        QList<QString> list;
        //添加列标题
        QString HeaderRow;
        for (int i = 0; i < col; i++)
        {
            HeaderRow.append(ui->tableView->model()->headerData(i, Qt::Horizontal, Qt::DisplayRole).toString() + "\t");
        }
        list.push_back(HeaderRow);
        for (int i = 0; i < row; i++)
        {
            QString rowStr = "";
            for (int j = 0; j < col; j++
要将PyQt5QTableView导出Excel,需要使用openpyxl库来处理Excel文件。下面是一个简单的示例代码: ```python import sys from PyQt5.QtWidgets import QApplication, QMainWindow, QTableView from PyQt5.QtCore import Qt from openpyxl import Workbook class MainWindow(QMainWindow): def __init__(self): super().__init__() self.table_view = QTableView(self) self.setCentralWidget(self.table_view) # 创建测试数据 self.table_data = [[str(i*j) for i in range(10)] for j in range(10)] # 在表格视图显示数据 model = MyTableModel(self.table_data, self) self.table_view.setModel(model) # 导出Excel按钮 self.export_button = QPushButton("导出Excel", self) self.export_button.clicked.connect(self.export_to_excel) self.export_button.setGeometry(10, 10, 100, 30) def export_to_excel(self): # 创建一个新的Excel工作簿 wb = Workbook() ws = wb.active # 将QTableView数据写入Excel工作表 for row in range(self.table_view.model().rowCount()): for column in range(self.table_view.model().columnCount()): item = self.table_view.model().data(self.table_view.model().index(row, column), Qt.DisplayRole) ws.cell(row=row+1, column=column+1, value=item) # 保存Excel文件 wb.save("table_data.xlsx") if __name__ == '__main__': app = QApplication(sys.argv) window = MainWindow() window.show() sys.exit(app.exec_()) ``` 上述代码,我们创建了一个MainWindow类,该类继承自QMainWindow。在其,我们创建了一个QTableView来显示表格数据,并使用自定义的MyTableModel类作为模型。点击"导出Excel"按钮时,会调用export_to_excel函数来将表格数据导出Excel文件。 需要注意的是,我们需要安装openpyxl库,可以使用以下命令进行安装: ``` pip install openpyxl ```
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值