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,一经查实,立即删除!

相关文章

圆圈序号1~10复制粘贴直接用

1. 空心圆圈数字序号&#xff1a; ①、②、③、④、⑤、⑥、⑦、⑧、⑨、⑩ 2. 实心圆圈数字序号&#xff1a; ❶、❷、❸、❹、❺、❻、❼、❽、❾、❿ 3. 空心圆圈中文序号&#xff1a; ㊀、㊁、㊂、㊃、㊄、㊅、㊆、㊇、㊈、㊉

linux高级编程(线程)(1)

虚拟地址&#xff1a; 线程&#xff1a; 概念&#xff1a;线程是轻量级进程&#xff0c;一般是一个进程中的多个任务。 进程是系统中最小的资源分配单位。&#xff08;竞争计算机资源的最小单位&#xff09;&#xff08;进程能分配硬件资源&#xff0c;线程不行&#x…

解析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 …

Leetcode Java学习记录——栈和队列 IDEA

文章目录 栈和队列stack Classqueue InterfaceDeque Interfaceadd 和 push Priority Queue -- Class题目 codestyleIDEA 操作快捷键选择代码生成类 栈和队列 stack Class google stack java 8/12 empty() peek() pop() push(E item) search(Object o) 最近相关性会用到栈 …

湘潭大学软件工程数据库总结

文章目录 前言试卷结构给学弟学妹的一些参考自己的一些总结 前言 自己可能很早很早之前就准备复习了&#xff0c;但是感觉还是没有学到要点&#xff0c;主要还是没啥紧迫的压力&#xff0c;我们是三月份开学&#xff0c;那时候实验室有朋友挺认真开始学习数据库了&#xff0c;…

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

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

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

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

Kafka 入门指南

Kafka 入门指南 简介 Kafka 是一个由 Apache 软件基金会开发的开源流处理平台。它最初由 LinkedIn 开发&#xff0c;并在 2011 年作为开源项目发布。Kafka 是一个分布式、可扩展、高吞吐量的消息队列系统&#xff0c;广泛应用于实时数据流处理场景。 主要概念 1. 主题 (Top…

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;相减…

关于redis的运维面试题-1

1. 什么是Redis&#xff1f; Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的内存数据结构存储&#xff0c;通常用作数据库、缓存和消息代理。它支持多种数据结构&#xff0c;如字符串&#xff08;strings&#xff09;、哈希&#xff08;hashes&#xff0…

大二暑假 + 大三上

希望&#xff0c;暑假能早睡早起&#xff0c;胸围达到 95&#xff0c;腰围保持 72&#xff0c;大臂 36&#xff0c;小臂 32&#xff0c;小腿 38&#x1f36d;&#x1f36d; 目录 &#x1f348;暑假计划 &#x1f339;每周进度 &#x1f923;寒假每日进度&#x1f602; &…

DiskGeniusV5.6.0.1565发布!

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

JS hook

参照&#xff1a; JS 逆向之 Hook JS Hook 与 过 debugger 一、常用Hook 1. eval (function() {let _eval eval;eval function(val) {if (val.indexof(debugger) -1) {_eval_cache(obj);}} })(); 2. JSON.parse() (function () {var parse_ JSON.parse;JSON.parse …

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…

堆排序(Heap Sort)

堆排序是一种高效的排序算法&#xff0c;它利用了堆的数据结构来实现。堆是一种特殊的完全二叉树&#xff0c;分为最大堆和最小堆两种类型。在最大堆中&#xff0c;父节点的值大于等于其子节点的值&#xff1b;而在最小堆中&#xff0c;父节点的值小于等于其子节点的值。 堆排…

【C命名规范】遵循良好的命名规范,提高代码的可读性、可维护性和可复用性

/******************************************************************** * brief param return author date version是代码书写的一种规范 * brief &#xff1a;简介&#xff0c;简单介绍函数作用 * param &#xff1a;介绍函数参数 * return&#xff1a;函数返回类型说明 * …

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

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