qt中数据库和excel互导数据————附带详细步骤和代码

文章目录

  • 0 背景
  • 1 准备QXlsx环境
    • 1.1 cmake安装使用
    • 1.2 qmake使用
  • 2 把excel数据导出到mysql数据库
  • 3 把mysql数据库的数据写入到excel
  • 4 完整代码
  • 5 项目代码仓库

0 背景

因为需要批量导入和导出数据,所以需要用到excel。实现把数据库的数据导入到excel中,把excel中的数据导出到数据库。这里使用了开源代码库QXlsx。

1 准备QXlsx环境

官网中的qmake的使用方法,cmake的使用方法。

1.1 cmake安装使用

  • 1,输入下列指令安装:
mkdir build
cd build
cmake ../QXlsx/ -DCMAKE_INSTALL_PREFIX=... -DCMAKE_BUILD_TYPE=Release
cmake --build .
cmake --install .

在CMakeLists.txt中添加如下内容:

find_package(QXlsxQt5 REQUIRED) # or QXlsxQt6
target_link_libraries(myapp PRIVATE QXlsx::QXlsx)
  • 2,下面是无需安装的两种使用方法:

使用cmake的子目录在 CMakeLists.txt:

add_subdirectory(QXlsx)
target_link_libraries(myapp PRIVATE QXlsx::QXlsx)

使用 cmake FetchContent 在 CMakeLists.txt:

FetchContent_Declare(QXlsxGIT_REPOSITORY https://github.com/QtExcel/QXlsx.gitGIT_TAG        sha-of-the-commitSOURCE_SUBDIR  QXlsx
)
FetchContent_MakeAvailable(QXlsx)
target_link_libraries(myapp PRIVATE QXlsx::QXlsx)

如果 QT_VERSION_MAJOR没有设置, QXlsx’s的 CMakeLists.txt 将尝试自己寻找 Qt 版本(5 或 6)。

1.2 qmake使用

下载QXsx的github项目代码。

  • 1,把QXsx项目中的代码(选中的三个项目)复制到自己项目下;

在这里插入图片描述

复制到自己项目下(新建一个QXlxs文件夹,存储文件):
在这里插入图片描述

在这里插入图片描述

  • 2,在pro中添加如下代码;
QXLSX_PARENTPATH=./         # current QXlsx path is . (. means curret directory)
QXLSX_HEADERPATH=./QXlsx/header/  # current QXlsx header path is ./header/
QXLSX_SOURCEPATH=./QXlsx/source/  # current QXlsx source path is ./source/
include(./QXlsx/QXlsx.pri)
  • 3,编译文件后,会自动把文件添加到项目中(绿色的那一部分);

  • 4,添加如下头文件,就可以开始项目编写;
#include "xlsxdocument.h"
#include "xlsxchartsheet.h"
#include "xlsxcellrange.h"
#include "xlsxchart.h"
#include "xlsxrichstring.h"
#include "xlsxworkbook.h"

测试程序:

// main.cpp#include <QCoreApplication>#include "xlsxdocument.h"
#include "xlsxchartsheet.h"
#include "xlsxcellrange.h"
#include "xlsxchart.h"
#include "xlsxrichstring.h"
#include "xlsxworkbook.h"
using namespace QXlsx;int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);QXlsx::Document xlsx;xlsx.write("A1", "Hello Qt!"); // write "Hello Qt!" to cell(A,1). it's shared string.xlsx.saveAs("Test.xlsx"); // save the document as 'Test.xlsx'return 0;// return a.exec();
}

2 把excel数据导出到mysql数据库

  • 1,准备要导入的账号和密码的excel表(第一行为数据库的字段名,必须一样;如果数据库中字段值不能为空,excel中数据也不能为空);
    在这里插入图片描述
    账号信息.xlsx

在这里插入图片描述
数据库中的login_information表

  • 2,在数据库中创建表格;
DROP TABLE IF EXISTS `login_information`;
CREATE TABLE `login_information`  (`account` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,`password` varchar(255) CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci NOT NULL,PRIMARY KEY (`account`) USING BTREE
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_unicode_ci ROW_FORMAT = DYNAMIC;
  • 3,建立数据库连接;

方法:

static bool CreateConnection(){//        qDebug()<<"查看目前可用驱动";//        QStringList drivers = QSqlDatabase::drivers();//        for(auto driver: drivers){//            qDebug()<<driver<<" ";//        }//设置数据库驱动QSqlDatabase mysqlDB = QSqlDatabase::addDatabase("QMYSQL", "mysql_connection1");mysqlDB.setHostName("192.168.0.104");mysqlDB.setUserName("root");mysqlDB.setPassword("password");mysqlDB.setPort(8889);mysqlDB.setDatabaseName("test_db");//根据系统环境设计数据库路径// Q_OS_LINUX:Q_OS_WIN: Q_OS_MAC   Q_OS_WIN32//如果远程mysql数据库没有打开if(!mysqlDB.open()){return false;}else{// #ifdef Q_OS_WINmysqlDB.exec("SET NAMES 'GBK'");// #endif// #ifdef Q_OS_MAC// #endif}//QSqlDatabase sqliteDB = QSqlDatabase::addDatabase("QSQLITE", "sqlite_connection1");// #ifdef Q_OS_WIN //Q_OS_WIN32//     qDebug()<<"QCoreApplication::applicationDirPath():"<<QCoreApplication::applicationDirPath();//     sqliteDB.setDatabaseName(QCoreApplication::applicationDirPath() + QString("/database/LocalSystemDatabse.db"));// #endif//如果本地sqlite数据库没有打开// if(!sqliteDB.open()){//     QMessageBox* databaseInformationBox = new QMessageBox(QMessageBox::Critical, ("信息提示"),  ("不能建立本地数据库连接!"), QMessageBox::Yes);//     auto button =  databaseInformationBox->exec();//     if(button == QMessageBox::Yes){//         databaseInformationBox->deleteLater();//     }//     return false;// }return true;}

调用:

//main中创建数据库连接
int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);//连接数据库if (!CreateConnection()){qDebug()<<"数据库连接失败";}return a.exec();
}
  • 4,把excel中的数据导入到数据库中;
bool exportExcel2Database(QStringList filePaths,  QString xlsxName, QString sqlSentence){QList<bool> execResultList;//操作的结果集bool execResult = false;QSqlDatabase db = QSqlDatabase::database("mysql_connection1");QSqlQuery query(db);if(db.transaction()){foreach(QString filePath, filePaths) {QXlsx::Document xlsx(filePath);if(!xlsx.selectSheet(xlsxName)){/*在当前打开的xlsx文件中,找一个名字为ziv的sheet*///xlsx.addSheet(xlsxName);//找不到的话就添加一个名为ziv的sheetqDebug()<<"没有对应的xlsx表";return false;}else{}QQueue<QString> tableFieldQueue;QHash<QString, QVariantList> tableAlterFiledValue;for(int row = 1; row <= xlsx.dimension().rowCount(); row++) {// 获取每行的数据并插入到数据库中for(int col = 1; col <= xlsx.dimension().columnCount();col++){if(row == 1){tableFieldQueue.enqueue(xlsx.read(row, col).toString());}else{tableAlterFiledValue[tableFieldQueue[col-1]].append(xlsx.read(row, col));}}}query.prepare(sqlSentence);foreach (QString tableFiled, tableFieldQueue) {query.addBindValue(tableAlterFiledValue[tableFiled]);}execResult = query.execBatch();execResultList.append(execResult);if(!execResult) {//批量执行数据插入qDebug() <<  query.lastError().databaseText();}}foreach (bool result, execResultList) {if(result == false){if(!db.rollback()){qDebug() << "数据库回滚失败"<<db.lastError().databaseText(); //回滚}else{qDebug()<<"数据库回滚成功";}return false;}}if(db.commit()){return true;}else{return false;}}return false;
}

调用:

    QStringList filePaths;filePaths<<"D:/test/账号信息.xlsx";//考试细节步骤QString sql2 = QString("INSERT INTO  login_information(account, password)  VALUES (?, ?)");QString xlsxName2 = "账号信息";// qDebug()<<sql2;if(exportExcel2Database(filePaths, xlsxName2, sql2)){qDebug()<<"导入成功";}else{qDebug()<<"导入失败";}

,

3 把mysql数据库的数据写入到excel

  • 1,建立数据库连接,同上;

  • 2,把数据库中表的数据导出到excel中;

bool exportData2XLSX(QString fileName, QString tableName)
{QXlsx::Document xlsx;QXlsx::Format format1;/*设置标题单元的样式*/format1.setFontSize(12);/*设置字体大小*/format1.setHorizontalAlignment(QXlsx::Format::AlignHCenter);/*横向居中*///format1.setBorderStyle(QXlsx::Format::BorderThin);/*边框样式*///format1.setFontBold(true);/*设置加粗*/if(!xlsx.selectSheet("表格数据")){/*在当前打开的xlsx文件中,找一个名字为ziv的sheet*/xlsx.addSheet("表格数据");//找不到的话就添加一个名为ziv的sheet}QSqlDatabase db = QSqlDatabase::database("mysql_connection1");QString tmpSql = QString("SELECT * FROM %1").arg(tableName);QSqlQuery query(db);if(query.exec(tmpSql)){//表头列QSqlRecord queryRecord(query.record());qDebug()<<"queryRecord.count():"<<queryRecord.count();for(int colNum = 0; colNum < queryRecord.count(); colNum++){//qDebug() <<  queryRecord.fieldName(colNum);xlsx.write(1, colNum+1,  queryRecord.fieldName(colNum),format1);}//表格数据int rowNum = 2;while(query.next()){for(int colNum = 0; colNum < queryRecord.count(); colNum++){xlsx.write(rowNum, colNum + 1, query.value(colNum),format1);}rowNum++;}}else{return false;}if(fileName.isEmpty())return false;xlsx.saveAs(fileName);//保存文件return true;
}

调用:


int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);//连接数据库if (!CreateConnection()){qDebug()<<"数据库连接失败";}QString tableName = "login_information";QString fileName = "D:/账号.xlsx";if(exportData2XLSX(fileName, tableName)){qDebug()<<"导入excel成功";}else{qDebug()<<"导入excel失败";}return a.exec();
}

4 完整代码

#include <QCoreApplication>#include "create_connection.h"#include "xlsxdocument.h"
#include "xlsxchartsheet.h"
#include "xlsxcellrange.h"
#include "xlsxchart.h"
#include "xlsxrichstring.h"
#include "xlsxworkbook.h"#include <QSqlError>
#include <QQueue>
#include <QHash>
#include <QSqlRecord>bool exportExcel2Database(QStringList filePaths,  QString xlsxName, QString sqlSentence){QList<bool> execResultList;bool execResult = false;QSqlDatabase db = QSqlDatabase::database("mysql_connection1");QSqlQuery query(db);if(db.transaction()){foreach(QString filePath, filePaths) {QXlsx::Document xlsx(filePath);if(!xlsx.selectSheet(xlsxName)){/*在当前打开的xlsx文件中,找一个名字为ziv的sheet*///xlsx.addSheet(xlsxName);//找不到的话就添加一个名为ziv的sheetqDebug()<<"没有对应的xlsx表";return false;}else{}QQueue<QString> tableFieldQueue;QHash<QString, QVariantList> tableAlterFiledValue;for(int row = 1; row <= xlsx.dimension().rowCount(); row++) {// 获取每行的数据并插入到数据库中for(int col = 1; col <= xlsx.dimension().columnCount();col++){if(row == 1){tableFieldQueue.enqueue(xlsx.read(row, col).toString());}else{tableAlterFiledValue[tableFieldQueue[col-1]].append(xlsx.read(row, col));}}}query.prepare(sqlSentence);foreach (QString tableFiled, tableFieldQueue) {query.addBindValue(tableAlterFiledValue[tableFiled]);}execResult = query.execBatch();execResultList.append(execResult);if(!execResult) {//批量执行数据插入qDebug() <<  query.lastError().databaseText();}}foreach (bool result, execResultList) {if(result == false){if(!db.rollback()){qDebug() << "数据库回滚失败"<<db.lastError().databaseText(); //回滚}else{qDebug()<<"数据库回滚成功";}return false;}}if(db.commit()){return true;}else{return false;}}return false;
}bool exportData2XLSX(QString fileName, QString tableName)
{QXlsx::Document xlsx;QXlsx::Format format1;/*设置标题单元的样式*/format1.setFontSize(12);/*设置字体大小*/format1.setHorizontalAlignment(QXlsx::Format::AlignHCenter);/*横向居中*///format1.setBorderStyle(QXlsx::Format::BorderThin);/*边框样式*///format1.setFontBold(true);/*设置加粗*/if(!xlsx.selectSheet("表格数据")){/*在当前打开的xlsx文件中,找一个名字为ziv的sheet*/xlsx.addSheet("表格数据");//找不到的话就添加一个名为ziv的sheet}QSqlDatabase db = QSqlDatabase::database("mysql_connection1");QString tmpSql = QString("SELECT * FROM %1").arg(tableName);QSqlQuery query(db);if(query.exec(tmpSql)){//表头列QSqlRecord queryRecord(query.record());qDebug()<<"queryRecord.count():"<<queryRecord.count();for(int colNum = 0; colNum < queryRecord.count(); colNum++){//qDebug() <<  queryRecord.fieldName(colNum);xlsx.write(1, colNum+1,  queryRecord.fieldName(colNum),format1);}//表格数据int rowNum = 2;while(query.next()){for(int colNum = 0; colNum < queryRecord.count(); colNum++){xlsx.write(rowNum, colNum + 1, query.value(colNum),format1);}rowNum++;}}else{return false;}if(fileName.isEmpty())return false;xlsx.saveAs(fileName);//保存文件return true;
}int main(int argc, char *argv[])
{QCoreApplication a(argc, argv);//连接数据库if (!CreateConnection()){qDebug()<<"数据库连接失败";}QString tableName = "login_information";QString fileName = "D:/账号.xlsx";if(exportData2XLSX(fileName, tableName)){qDebug()<<"导入excel成功";}else{qDebug()<<"导入excel失败";}return a.exec();
}

5 项目代码仓库

代码仓库(欢迎star):

github仓库
码云

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/web/37782.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

解析QAnything启动命令过程

一.启动命令过程日志 启动命令bash ./run.sh -c local -i 0 -b hf -m Qwen-1_8B-Chat -t qwen-7b-chat。输入日志如下所示&#xff1a; rootMM-202203161213:/mnt/l/20230918_RAG方向/QAnything# bash ./run.sh -c local -i 0 -b hf -m Qwen-1_8B-Chat -t qwen-7b-chat From …

理性决策的艺术:从购房到择偶的数学智慧;37% 规则,做出最佳决策的秘诀;用数学模型解决人生难题

在面对人生重大决策时&#xff0c;如购房或择偶&#xff0c;我们常常感到迷茫和困惑。然而&#xff0c;如果我们能够将这些看似复杂的问题简化为数学模型&#xff0c;我们就能以更加理性和系统的方式做出决策。 37%规则 1950年代&#xff0c;当时几位数学家开始研究这样一个问…

值得收藏!盘点那些适合普通人方便又好用的AIGC工具!(下)

【导读】接上一篇文章&#xff0c;盘点国内外适合普通人能够轻松上手的AIGC工具&#xff08;上&#xff09;。今天又为大家整理了一些好用又方便的AI设计工具、AI办公工具、AI编程工具、AI指令工具和AI检测工具&#xff0c;如果有没更新到的工具也欢迎大家评论区交流。 一 、A…

C#/WPF 自制截图工具

在日常使用电脑办公时&#xff0c;我们经常遇到需要截图然后保存图片&#xff0c;我们往往需要借助安装截图工具才能实现&#xff0c;现在我们通过C#自制截图工具&#xff0c;也能够轻松进行截图。 我们可以通过C#调用WindousAPI来实现截图&#xff0c;实例代码如下&#xff1a…

AI基本概念(人工智能、机器学习、深度学习)

人工智能 、 机器学习、 深度学习的概念和关系 人工智能 &#xff08;Artificial Intelligence&#xff09;AI- 机器展现出人类智慧机器学习 &#xff08;Machine Learning) ML, 达到人工智能的方法深度学习 &#xff08;Deep Learning&#xff09;DL,执行机器学习的技术 从范围…

算法 —— 滑动窗口

目录 长度最小的子数组 无重复字符的最长子串 最大连续1的个数 将x减到0的最小操作数 找到字符串中所有字母异位词 长度最小的子数组 sum比target小就进窗口&#xff0c;sum比target大就出窗口&#xff0c;由于数组是正数&#xff0c;所以相加会使sum变大&#xff0c;相减…

DiskGeniusV5.6.0.1565发布!

DiskGenius是一款功能强大的磁盘管理和数据恢复工具&#xff0c;V5.6.0.1565上线。新版本变化比较大&#xff0c;增加新的功能&#xff0c;修正已经问题&#xff0c;值得试一下。提醒大家&#xff0c;磁盘管理软件涉及数据安全&#xff0c;请始终使用最新版本&#xff01; 下面…

C++ initializer_list类型推导

目录 initializer_list C自动类型推断 auto typeid decltype initializer_list<T> C支持统一初始化{ }&#xff0c;出现了一个新的类型initializer_list<T>&#xff0c;一切类型都可以用列表初始化。提供了一种更加灵活、安全和明确的方式来初始化对象。 class…

IO-Link OD介绍

IO-Link OD&#xff08;On-request Data&#xff0c;按需数据&#xff09;是IO-Link通信中的一种重要数据类型&#xff0c;主要用于参数读写、指令交互、事件上传等动作。以下是关于IO-Link OD的结构、构成以及功能使用的详细说明&#xff1a; 结构与构成 定义&#xff1a;OD…

同一个excel表格,为什么在有的电脑上会显示#NAME?

一、哪些情况会产生#NAME?的报错 1.公式名称拼写错误 比如求和函数SUM&#xff0c;如果写成SUN就会提示#NAME&#xff1f;报错。 2.公式中的文本值未添加双引号 如下图&#xff1a; VLOOKUP(丙,A:B,2,0) 公式的计算结果会返回错误值#NAME?&#xff0c;这是因为公式中文本…

【PLC】三菱PLC如何和汇川伺服实现485通信

前言 一开始选用的是汇川SV660P脉冲型伺服&#xff0c;由于生产需求需要对伺服的个别参数进行读取和写入操作&#xff0c;但是SV660P并不支持这种情况&#xff0c;因此需要使用485通信来满足。PLC这边选用的是三菱FX5U。 开始 1、首先准备按照下图的引脚提示准备好一根带屏蔽…

(七)glDrawArry绘制

几何数据&#xff1a;vao和vbo 材质程序&#xff1a;vs和fs(顶点着色器和片元着色器) 接下来只需要告诉GPU&#xff0c;使用几何数据和材质程序来进行绘制。 #include <glad/glad.h>//glad必须在glfw头文件之前包含 #include <GLFW/glfw3.h> #include <iostrea…

PostgreSQL的学习心得和知识总结(一百四十七)|深入理解PostgreSQL数据库之transaction chain的使用和实现

目录结构 注&#xff1a;提前言明 本文借鉴了以下博主、书籍或网站的内容&#xff0c;其列表如下&#xff1a; 1、参考书籍&#xff1a;《PostgreSQL数据库内核分析》 2、参考书籍&#xff1a;《数据库事务处理的艺术&#xff1a;事务管理与并发控制》 3、PostgreSQL数据库仓库…

2024年文化传播与对外交流国际学术会议(ICCCFE 2024)

2024年文化传播与对外交流国际学术会议&#xff08;ICCCFE 2024&#xff09; 2024 International Conference on Cultural Communication and Foreign Exchange(ICCCFE 2024) 会议简介&#xff1a; 2024年文化传播与对外交流国际学术会议&#xff08;ICCCFE 2024&#xff09;定…

clion开发51 没有创建成功可能是Clion版本问题

安装插件 PlatformlO for CLion 进入这个网站下载get-platformio.py https://docs.platformio.org/en/latest/core/installation/methods/installer-script.html#local-download-macos-linux-windows 点击 Installation Methods 选择 Local Download (macOS/Linux/Windows) 点…

小阿轩yx-案例:MySQL主从复制与读写分离

小阿轩yx-案例&#xff1a;MySQL主从复制与读写分离 案例分析 概述 实际生产环境中 如果对数据库读和写都在同一个数据库服务器中操作&#xff0c;无论在安全性、高可用性还是高并发等各个方面都完全不能满足实际需求一般都是通过主从复制&#xff08;Master-Slave&#xf…

MSPG3507——蓝牙接收数据显示在OLED,滴答定时器延时500MS

#include "ti_msp_dl_config.h" #include "OLED.h" #include "stdio.h"volatile unsigned int delay_times 0;//搭配滴答定时器实现的精确ms延时 void delay_ms(unsigned int ms) {delay_times ms;while( delay_times ! 0 ); } int a0; …

20人团队如何免费使用 Atlassian 云产品?

企业赚钱越来越难&#xff0c;尤其是初创团队或小型团队更倾向于使用免费工具支持业务。团队规模影响协作复杂度&#xff0c;Atlassian 考虑到小团队的需求&#xff0c;提供了多种选择。比如&#xff0c;Jira 和 Confluence 的云版本有免费版&#xff0c;包含基本的项目管理功能…

ISP IC/FPGA设计-第一部分-SC130GS摄像头分析(0)

1.介绍 SC130GS是一款国产的Global shutter CMOS图像传感器&#xff0c;最高支持1280Hx1024V240fps的传输速率&#xff1b;SC130GS有黑白和彩色款&#xff0c;作为ISP开发选择彩色的&#xff0c;有效像素窗口为1288Hx1032V&#xff0c;支持复杂的片上操作&#xff0c;选择他理…

Toshiba东芝TB6612FNG电机驱动IC:释放性能与多功能性

在嵌入式系统和机器人技术领域&#xff0c;电机控制是一个关键方面&#xff0c;对项目的性能和可靠性有着显著影响。东芝的TB6612FNG电机驱动IC作为一个稳健且多功能的解决方案&#xff0c;在驱动双直流电机方面脱颖而出&#xff0c;提供了高性能、可靠性和易用性。本文将深入探…