Qt导出Excel图表

目的

就是利用Qt导出Excel图表,如果直接画Excel 图表,比较麻烦些,代码写得也复杂了;而直接利用Excel模块就简单了,图表在模块当中已经是现成的了,Qt程序只更改数据就可以了,这篇文章就是记录一下利用模块上的图表生成Excel图表的过程。

模块选择上,QtXlsxWriter,这一个模块功能较简单一些,看看网上github库,也知道,已经好久不更新了,而且也没有打开现在Excel的功能;QT自带的那个QAxObject,很难用,用户使用体验极差。

综合来说,只能选择QXlsx.

QXlsx的介绍:

QXlsx 是一个非官方的、独立的 Qt 库,用于读写 Excel 文件(.xlsx 格式)。这个库提供了一个方便的方式来创建新的 Excel 文档或编辑现有文档,而不依赖于 COM 或其他外部接口,使其适用于跨平台应用程序。

QXlsx 的主要特性

读取和写入 Excel 文件:

支持从 .xlsx 文件中读取数据,并能够写入新数据或修改现有数据。

支持单元格格式:

可以设置字体、边框、颜色、对齐方式等多种单元格格式。

多种数据类型:

支持字符串、数字、日期和时间等多种类型的数据输入。

公式和函数:

可以在单元格中使用 Excel 公式,例如 SUM、AVERAGE 等。

图表支持:

可以创建基本的图表,如条形图、折线图等。

合并单元格:

支持合并和拆分单元格。

图像和注释:

可以在工作表中插入图像和添加注释。

相关材料

第三方模块:

https://github.com/QtExcel/QXlsx/wiki

基本用法的介绍:

https://github.com/QtExcel/QXlsx/wiki

这一个代码有些陈旧了:

https://github.com/dbzhang800/QtXlsxWriter

情况分析

首先建立Excel文档,作为模板用:



这样Excel模块上的图表,表格的数据都是来源于Sheet2上面的数据,这样代码只需要设置Sheet2上的数据就可以了。

代码调用模块:

项目结构:

代码情况:

cpp 复制代码
#pragma execution_character_set("utf-8")
#include <QCoreApplication>
#include "xlsxdocument.h"
#include <QDebug>
using namespace QXlsx;
/**
 * @brief writeToExcelSheet2
 * @param excelFilePath Excel的路径
 * @param sheetNumber  操作数据所在的表
 * @param beginRow     数据所开始的行
 * @param beginColumn  数据所开始的例
 * @param data         二维数据,行列数据
 */
void writeToExcelSheet2(const QString &excelFilePath, int sheetNumber,
                       int beginRow, int beginColumn, QVector<QVector<double>> &data) {
    qDebug("enter function writeToExcelSheet2");
    //加载模板
    QXlsx::Document xlsx(excelFilePath);
    if (!xlsx.load())
    {
        qDebug() << "load failed!!!";
        return;
    }
    qDebug() << "excelFilePath=" << excelFilePath << ", data=" << data << ",count=" << xlsx.sheetNames().count();
    qDebug() << "xlsx.sheetNames()=" << xlsx.sheetNames();
    QVector<double> rowVector;
    //选择所指定的工作表
    if(xlsx.selectSheet(sheetNumber))
    {
        for(int i = 0; i < data.size(); i++)
        {
            rowVector = data[i];
            for(int j = 0; j < rowVector.size(); j++)
            {
                // 写入数据
                Format format = xlsx.cellAt(beginRow+j, beginColumn+i)->format();
                xlsx.write(beginRow+j, beginColumn+i, QVariant(rowVector[j]).toDouble(), format);
            }
        }
        // 保存文件
        xlsx.save();
    }
    qDebug("exit function writeToExcelSheet2");
}
int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);
    QString currentPath = QCoreApplication::applicationDirPath();
    QString excelFilePath = currentPath+"\\scoreRanking.xlsx";
    int sheetNumber = 1; // 假设我们要操作的是第二个工作表
    //int row = 2; // 假设我们要写入的行号是1
    //int column = 1; // 假设我们要写入的列号是1
    //写Sheet2的1列的成绩数据
    QVector<QVector<double>> data1 = {{40, 62, 63, 65, 67, 68, 69, 71, 72, 78,
                                       81, 82, 81, 82, 83, 84, 85, 86, 87, 88,
                                       91, 92, 93, 94, 95, 96, 97, 98, 100, 120}};
    writeToExcelSheet2(excelFilePath, sheetNumber,
                           2, 1, data1);
    //写Sheet2的2列的班级名次数据
    data1 = {{40, 39, 38, 37, 36, 35, 34, 33, 32, 31,
               30, 29, 28, 27, 26, 25, 24, 23, 22, 21,
               20, 19, 18, 17, 16, 15, 14, 13, 12, 10}};
    writeToExcelSheet2(excelFilePath, sheetNumber,
                           2, 2, data1);
    //写Sheet2的3列的学校名次数据
    data1 = {{240, 239, 238, 237, 236, 235, 234, 233, 232, 231,
               230, 229, 228, 227, 226, 225, 224, 223, 222, 221,
               220, 219, 218, 217, 216, 215, 214, 213, 212, 220}};
    writeToExcelSheet2(excelFilePath, sheetNumber,
                           2, 3, data1);
    return a.exec();
}

更改上面的数据后,执行代码,Excel的数据就会跟着变,由于效果与上面一样,只是数据变了,就不再贴图了。

注意事项

Excel 特性的支持程度:尽管 QXlsx 支持许多基本的 Excel 功能,但它可能不支持最新的或高级的 Excel 特性,如复杂的数据透视表或宏。

性能考虑:处理非常大的 Excel 文件时,性能可能会成问题。这需要在实际应用中进行测试。

QXlsx 提供了一个方便的方式来处理 Excel 文件,尤其适合那些不需要依赖 Microsoft Office 自动化、需要跨平台支持的应用程序。

总结

导出图表本身是一个挺麻烦的事,通过Excel的模板,就把麻烦事变成简单事了,QT程序只需要更新数据就可以了,这样处理简单,不用为控制Excel格式而费心了,而且显示的效果好,最后以图说明:

例子下载地址:https://download.csdn.net/download/maokexu123/90052338

相关推荐
wjm041006几秒前
C++的四种类型转换
java·开发语言·c++
今夜有雨.6 分钟前
使用C++实现HTTP服务
开发语言·网络·c++·后端·网络协议·tcp/ip·http
东方苾梦10 分钟前
Lua语言的安全开发
开发语言·后端·golang
eli96013 分钟前
lib-zo,C语言另一个协程库,dns协程化, gethostbyname
c语言·开发语言
可可南木15 分钟前
BT-Basic函数之首字母T
开发语言·测试工具·pcb工艺
慕离桑30 分钟前
HTML语言的数据可视化
开发语言·后端·golang
我命由我1234535 分钟前
C++ - 头文件基础(常用标准库头文件、自定义头文件、头文件引入方式、防止头文件重复包含机制)
服务器·c语言·开发语言·c++·后端·visualstudio·visual studio code
能来帮帮蒟蒻吗1 小时前
GO语言学习(17)Gorm的数据库操作
开发语言·学习·golang
Pacify_The_North1 小时前
【C++进阶五】list深度剖析
开发语言·c++·算法·list