【Qt】将数据导出到csv文件 您所在的位置:网站首页 QT写csv文件浮点数处理 【Qt】将数据导出到csv文件

【Qt】将数据导出到csv文件

2024-06-04 01:20| 来源: 网络整理| 查看: 265

实际项目中有存储大量数据到表格的需求。最开始我使用的是Qtxlsx,将数据导出为excel表格。Qtxlsx插件的好处在于跨平台,相比于Qt自带的excel表格操作类,Qtxlsx不要求宿主机上安装有office,同时其读写速度远超过Qt原生excel操作类。 但Qtxlsx也有缺点,一是需要编译、移植库等一系列操作后才可以使用;二是存储大量数据(几十万条数量级)时,其对内存的占用会迅速爬升,十万条100字段的数据,轻轻松松占到2G内存。这如果移植到嵌入式平台将是致命的缺点。 幸好有csv这般轻量级、易操作的表格存储手段,具体介绍见伟大的百度百科https://baike.baidu.com/item/CSV/10739?fr=aladdin,其精髓就是以逗号、引号分隔列,以换行符分隔行,从而形成表格。下面在上两篇博文例程【传送门】的基础上再加入一个功能:导出数据库内容到csv文件。 最新的【读取该表内所有记录】按钮的作用是读取指定表的数据并显示在tableview中,那么就在这里加入保存为csv文件的功能吧。 在之前的基础上包含头文件

#include #include #include

在上两篇的基础上,在void MainWindow::on_pushButton_4_clicked()中增加相应代码。

//显示所选表所有内容 void MainWindow::on_pushButton_4_clicked() { QString cmd; QSqlQueryModel *model; model = new QSqlQueryModel(); cmd += "select * from "; cmd += ui->lineEdit->text(); model->setQuery(cmd); ui->tableView->setModel(model); //以下是保存csv int row,col,i,j; QFile file; QString fileName; QModelIndex index; row = model->rowCount(); //获取当前tableview行列数 col = model->columnCount(); fileName = QFileDialog::getSaveFileName(this, tr("保存表格"), QDir::currentPath() + "/" +\ ui->lineEdit->text() + ".csv", tr("csv File(*.csv)")); if(fileName.isNull()) { return; } file.setFileName(fileName); if(!file.open(QIODevice::WriteOnly | QIODevice::Text)) { qDebug()


【本文地址】

公司简介

联系我们

今日新闻

    推荐新闻

    专题文章
      CopyRight 2018-2019 实验室设备网 版权所有