Qt导出Excel图表

news2024/11/29 18:52:08

目的

就是利用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上的数据就可以了。

代码调用模块:
项目结构:
在这里插入图片描述

代码情况:

#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

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

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

相关文章

DeSTSeg: Segmentation Guided Denoising Student-Teacher for Anomaly Detection

DeSTSeg: Segmentation Guided Denoising Student-Teacher for Anomaly Detection 清华、苹果 个人感觉 Introduction 很自然的让读者理解作者问题的提出&#xff0c;也有例子直接证明了这个问题的存在&#xff0c;值得借鉴&#xff01;&#xff01; Related work写的也很不…

Java设计模式 —— 【创建型模式】工厂模式(简单工厂、工厂方法模式、抽象工厂)详解

文章目录 前言一、简单工厂&#xff08;静态工厂&#xff09;1、概述2、代码实现3、优缺点 二、工厂方法模式1、概述2、代码实现3、优缺点 三、抽象工厂模式1、概述2、代码实现3、优缺点 四、总结 前言 先看个案例&#xff1a;【手机和手机店】在没有工厂的时候&#xff0c;手…

利用Java爬虫获取阿里巴巴中国站跨境属性的详细指南

在全球化贸易的浪潮中&#xff0c;跨境电商正成为连接全球买家和卖家的重要桥梁。阿里巴巴中国站作为全球领先的B2B电子商务平台&#xff0c;提供了海量的商品信息&#xff0c;其中跨境属性信息对于跨境电商尤为重要。本文将详细介绍如何使用Java编写爬虫&#xff0c;从阿里巴巴…

「Qt Widget中文示例指南」如何为窗口实现流程布局?(二)

Qt 是目前最先进、最完整的跨平台C开发工具。它不仅完全实现了一次编写&#xff0c;所有平台无差别运行&#xff0c;更提供了几乎所有开发过程中需要用到的工具。如今&#xff0c;Qt已被运用于超过70个行业、数千家企业&#xff0c;支持数百万设备及应用。 本文将展示如何为不…

鸿蒙学习使用模拟器运行应用(开发篇)

文章目录 1、系统类型和运行环境要求2、创建模拟器3、启动和关闭模拟器4、安装应用程序包和上传文件QA:在Windows电脑上启动模拟器&#xff0c;提示未开启Hyper-V 1、系统类型和运行环境要求 Windows 10 企业版、专业版或教育版及以上&#xff0c;且操作系统版本不低于10.0.18…

Java后端如何进行文件上传和下载 —— 本地版

简介&#xff1a; 本文详细介绍了在Java后端进行文件上传和下载的实现方法&#xff0c;包括文件上传保存到本地的完整流程、文件下载的代码实现&#xff0c;以及如何处理文件预览、下载大小限制和运行失败的问题&#xff0c;并提供了完整的代码示例。 大体思路 1、文件上传 …

SqlServer强制转换函数TRY_CONVERT和TRY_CAST

SqlServer强制转换函数TRY_CONVERT和TRY_CAST的介绍和案例分享 1、本节内容 CAST 和 CONVERT TRY_CAST TRY_CONVERT 适用于&#xff1a; SQL ServerAzure SQL 数据库Azure SQL 托管实例Azure Synapse Analytics 分析平台系统 (PDW)Microsoft Fabric 中的 SQL 分析端点Micro…

透视投影(Perspective projection)与等距圆柱投影(Equirectangular projection)

一、透视投影 1.方法概述 Perspective projection&#xff08;透视投影&#xff09;是一种模拟人眼观察三维空间物体时的视觉效果的投影方法。它通过模拟观察者从一个特定视点观察三维场景的方式来创建二维图像。在透视投影中&#xff0c;远处的物体看起来比近处的物体小&…

linux 中后端jar包启动不起来怎么回事 -bash: java: 未找到命令

一、用以下命令检查jdk版本 输入&#xff1a;java -version&#xff0c;如果JDK 环境变量没有配置&#xff0c;你会看到如下提示 二、配置jdk环境 1.先找到/etc/profile文件&#xff0c;然后在该文件最后面加上以下配置 export JAVA_HOME/usr/local/jdk-21.0.1 export PATH$…

TDengine在debian安装

参考官网文档&#xff1a; 官网安装文档链接 从列表中下载获得 Deb 安装包&#xff1b; TDengine-server-3.3.4.3-Linux-x64.deb (61 M) 进入到安装包所在目录&#xff0c;执行如下的安装命令&#xff1a; sudo dpkg -i TDengine-server-<version>-Linux-x64.debNOTE 当…

Java开发工程师最新面试题库系列——Java基础部分(附答案)

如果你有更好的想法请在评论区留下您的答案&#xff0c;一起交流讨论# 面向对象有哪些特征&#xff1f; 答&#xff1a;继承、封装、多态 JDK与JRE的区别是什么&#xff1f; 答&#xff1a;JDK是java开发时所需环境&#xff0c;它包含了Java开发时需要用到的API&#xff0c;JRE…

linux系统下如何将xz及ISO\img等格式压缩包(系统)烧写到优盘(TF卡)

最近用树莓派做了个NAS&#xff0c;效果一般&#xff0c;缺少监控及UI等&#xff0c;详细见这篇文章&#xff1a; https://blog.csdn.net/bugsycrack/article/details/135344782?spm1001.2014.3001.5501 所以下载了专门的基于树莓派的NAS系统直接使用。这篇文章是顺便复习一…

计算机的错误计算(一百六十八)

摘要 算式“(5^25*(1/25)^(1/5)*3^25(1/25)^(1/5)*5^25*3^(251/5)-(9/25)^(1/5)*3^25*5^25-(1/25)^(1/5)*3^25*5.0^25*(13^(1/5)-3^(2/5.0)))”的值为0。但是&#xff0c;在 MATLAB 中计算它&#xff0c;则输出含有15位整数。 例1. 计算 直接贴图吧&#xff1a; 这样&#x…

Python学习------第十四天

匿名函数 1.函数作为参数来传递 &#xff08;函数的参数中调用另外一个函数&#xff09; #定义一个函数&#xff0c;接受另一个函数作为参数传入 #计算逻辑的传入 def test_func(compute):result compute(1,2)print(result)print(f"{type(result)}")print(f"…

【经典论文阅读】Transformer(多头注意力 编码器-解码器)

Transformer attention is all you need 摘要 完全舍弃循环 recurrence 和卷积 convolutions 只依赖于attention mechanisms 【1】Introduction 完全通过注意力机制&#xff0c;draw global dependencies between input and output 【2】Background 1&#xff1a;self-…

Java——多线程案例

目录 一、单例模式 1.饿汉模式 2.懒汉模式 3.线程安全问题 4.解决线程安全问题(懒汉模式) 二、阻塞式队列 1.什么是阻塞队列 2.生产者消费模型 生产者消费者模型意义&#xff1a; 1.解耦合 2.削峰填谷 3.标准库中的阻塞队列 三、定时器 1.定时器是什么 2.标准库中的…

AI 声音:数字音频、语音识别、TTS 简介与使用示例

在现代 AI 技术的推动下&#xff0c;声音处理领域取得了巨大进展。从语音识别&#xff08;ASR&#xff09;到文本转语音&#xff08;TTS&#xff09;&#xff0c;再到个性化声音克隆&#xff0c;这些技术已经深入到我们的日常生活中&#xff1a;语音助手、自动字幕生成、语音导…

Linux服务器安装mongodb

因为项目需要做评论功能&#xff0c;领导要求使用mongodb&#xff0c;所以趁机多学习一下。 在服务器我们使用docker安装mongodb 1、拉取mongodb镜像 docker pull mongo &#xff08;默认拉取最新的镜像&#xff09; 如果你想指定版本可以这样 docker pull mongo:4.4&#…

Java基础 设计模式——针对实习面试

目录 Java基础 设计模式单例模式工厂模式观察者模式策略模式装饰器模式其他设计模式 Java基础 设计模式 单例模式 单例模式&#xff08;Singleton Pattern&#xff09; 定义&#xff1a;确保一个类只有一个实例&#xff0c;并提供一个全局访问点来访问这个实例。适用场景&…

分布式搜索引擎之elasticsearch单机部署与测试

分布式搜索引擎之elasticsearch单机部署与测试 1.部署单点es 1.1.创建网络 因为我们还需要部署kibana容器&#xff0c;因此需要让es和kibana容器互联。这里先创建一个网络&#xff1a; docker network create es-net1.2.加载镜像 这里我们采用elasticsearch的7.12.1版本的…