当前位置: 首页 > news >正文

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

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

代码情况:

#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

相关文章:

Qt导出Excel图表

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

分布式协同 - 分布式系统的特性与互斥问题

文章目录 导图概述分布式系统的特性与挑战分布式互斥算法的目标分布式互斥算法集中互斥算法集中互斥算法示意图集中互斥算法流程 基于许可的互斥算法Lamport 算法示意图Lamport 流程 令牌环互斥算法令牌环互斥算法示意图 1. 集中互斥算法&#xff08;Centralized Mutual Exclus…...

windows安装itop

本文介绍 win10 安装 itop 安装WAMP集成环境前 先安装visual c 安装itop前需要安装WAMP集成环境(windowsApacheMysqlPHP) 所需文件百度云盘 通过网盘分享的文件&#xff1a;itop.zip 链接: https://pan.baidu.com/s/1D5HrKdbyEaYBZ8_IebDQxQ 提取码: m9fh 步骤一&#xff1…...

LAMP环境的部署

一、软件安装介绍 在Linux系统中安装软件有rpm安装、yum安装、源码安装等方法&#xff0c;在这里主要给大家介绍 yum 安装&#xff0c;这是一种最简单方便的一种安装方法。 YUM&#xff08;Yellow dog Upadate Modifie&#xff09;是改进版的 RPM 管理器&#xff0c;很好地解…...

Go语言压缩文件处理

目录 Go 语言压缩文件处理1. 压缩文件&#xff1a;Zip函数2. 解压文件&#xff1a;UnZip 函数3. 小结 Go 语言压缩文件处理 在现代的应用开发中&#xff0c;处理压缩文件&#xff08;如 .zip 格式&#xff09;是常见的需求。Go 语言提供了内置的 archive/zip 包来处理 .zip 文…...

rocylinux9.4安装prometheus监控

一.上传软件包 具体的软件包如下&#xff0c;其中kubernetes-mixin是下载的监控kubernetes的一些监控规则、dashbaordd等。 二.Prometheus配置 1.promethes软件安装 #解压上传后的软件包 [rootlocalhost ] cd /opt [rootlocalhost opt]# tar xf prometheus-2.35.3.linux-amd…...

屏幕分辨率|尺寸|颜色深度指纹

一、前端通过window.screen接口获取屏幕分辨率 尺寸 颜色深度&#xff0c;横屏竖屏信息。 二、window.screen c接口实现&#xff1a; 1、third_party\blink\renderer\core\frame\screen.idl // https://drafts.csswg.org/cssom-view/#the-screen-interface[ExposedWindow ] …...

docker-elasticsearch-kibana-logstash

一、安装 Elasticsearch 尝试直接拉取 Elasticsearch 镜像&#xff1a; 执行 docker pull docker.elastic.co/elasticsearch/elasticsearch&#xff0c;拉取失败&#xff0c;错误提示为 “Error response from daemon: manifest for docker.elastic.co/elasticsearch/elasticse…...

C#设计模式——抽象工厂模式(重点)

文章目录 项目地址一、抽象工厂模式1.1 特性1.2 使用反射获取特性标记的类1.3 完整代码 项目地址 教程作者&#xff1a;教程地址&#xff1a; 代码仓库地址&#xff1a; 所用到的框架和插件&#xff1a; dbt airflow一、抽象工厂模式 工厂方法模式依然存在一个问题就是&…...

全新AI模型家族登场:完全可复现的开源语言模型OLMo 2

每周跟踪AI热点新闻动向和震撼发展 想要探索生成式人工智能的前沿进展吗&#xff1f;订阅我们的简报&#xff0c;深入解析最新的技术突破、实际应用案例和未来的趋势。与全球数同行一同&#xff0c;从行业内部的深度分析和实用指南中受益。不要错过这个机会&#xff0c;成为AI领…...

用Matlab和SIMULINK实现DPCM仿真和双边带调幅系统仿真

1、使用SIMULINK或Matlab实现DPCM仿真 1.1 DPCM原理 差分脉冲编码调制&#xff0c;简称DPCM&#xff0c;主要用于将模拟信号转换为数字信号&#xff0c;同时减少数据的冗余度以实现数据压缩。在DPCM中&#xff0c;信号的每个抽样值不是独立编码的&#xff0c;而是通过预测前一…...

RabbitMQ的交换机总结

1.direct交换机 2.fanout交换机...

Android so库的编译

在没弄明白so库编译的关系前,直接看网上博主的博文,常常会觉得云里雾里的,为什么一会儿通过Android工程cmake编译,一会儿又通过NDK命令去编译。两者编译的so库有什么区别? android版第三方库编译总体思路: 对于新手小白来说搞明白上面的总体思路图很有必…...

2024年底-Arch linux或转为0BSD许可证!

原文&#xff1a;https://archlinux.org/news/providing-a-license-for-package-sources/ 解读&#xff1a;Arch Linux社区通过RFC 40达成共识&#xff0c;决定将所有软件包源代码更改为0BSD许可证。 0BSD许可证是什么&#xff1f;&#xff1a;这是一个非常自由的开源许可证&a…...

深入解析音视频流媒体SIP协议交互过程

一、引言 在音视频流媒体传输过程中&#xff0c;SIP&#xff08;Session Initiation Protocol&#xff09;协议发挥着举足轻重的作用。本文将详细全面地介绍音视频流媒体传输中的SIP协议&#xff0c;包括其基本概念、交互过程、关键信令以及应用场景 二、SIP协议基本概念 1.…...

linux安装mysql8.0.40

一、下载MySQL安装包 1.查看glibc版本 rpm -qa | grep glibc 2.到mysql官网下载安装包 ​ 二、解压安装 1.上传压缩包纸/usr/local 目录下&#xff0c;解压&#xff1a; tar -xvf mysql-8.0.40-linux-glibc2.17-x86_64.tar.xz 2.重命名&#xff1a; mv mysql-8.0.40-linux-…...

Java基础之控制语句:开启编程逻辑之门

一、Java控制语句概述 Java 中的控制语句主要分为选择结构、循环结构和跳转语句三大类&#xff0c;它们在程序中起着至关重要的作用&#xff0c;能够决定程序的执行流程。 选择结构用于根据不同的条件执行不同的代码路径&#xff0c;主要包括 if 语句和 switch 语句。if 语句有…...

如何还原 HTTP 请求日志中的 URL 编码参数?详解 %40 到 @

在记录HTTP请求的日志中出现了这样的情况&#xff1a; 2024-11-20 11:12:49 INFO network_request gz_login 96 Body: countryAbbrCN&countryCode86&email1222405567%40qq.com&password12354e50456db124f9f34e2789308733&type1 出现这种情况的原因是&#x…...

usb_cam ros包话题说明,image transport包使用

1. /usb_cam/image_raw 类型: sensor_msgs/Image 内容: 摄像头采集的原始图像数据。 用途: 图像处理和分析&#xff0c;例如使用 OpenCV 处理图像。视频流可达10MB/s 图像流查看&#xff0c;例如用 rqt_image_view 进行显示&#xff1a; 2./usb_cam/image_raw/compressed …...

微前端-MicroApp

微前端即是由一个主应用来集成多个微应用&#xff08;可以不区分技术栈进行集成&#xff09; 下面是使用微前端框架之一 MicroApp 对 react微应用 的详细流程 第一步 创建主应用my-mj-app 利用脚手架 npx create-react-app my-mj-app 快速创建 安装 npm install --save rea…...

Unity UGUI 垂直循环复用滚动

一 基础类 在unity里面新建这几个类 using System; using System.Collections; using System.Collections.Generic; using UnityEngine; using UnityEngine.UI; /// <summary> /// 垂直方向滚动 /// </summary> public class CustomScroll:MonoBehaviour {public …...

Spring MVC 深度剖析:优势与劣势全面解读

文章目录 Spring MVC 优势1. **松耦合**2. **易于测试**3. **灵活性**4. **强大的配置机制**5. **异常处理**6. **国际化支持**7. **数据验证**8. **安全性**9. **性能优化** Spring MVC 劣势1. **学习曲线**2. **配置复杂性**3. **性能开销**4. **视图技术限制**5. **社区和支…...

力扣hot100-->前缀和/前缀书/LRU缓存

前缀和 1. 560. 和为 K 的子数组 中等 给你一个整数数组 nums 和一个整数 k &#xff0c;请你统计并返回 该数组中和为 k 的子数组的个数 。 子数组是数组中元素的连续非空序列。 示例 1&#xff1a; 输入&#xff1a;nums [1,1,1], k 2 输出&#xff1a;2示例 2&#…...

Three.js CSS2D/CSS3D渲染器

在Three.js开发过程中&#xff0c;有时需要将 HTML 元素与 Three.js 渲染的 3D 场景相结合&#xff0c;这就需要用到 CSS2DRenderer 和 CSS3DRenderer。本文将详细介绍这两种渲染器的原理及其应用 一、CSS2DRenderer 渲染器 概述 CSS2DRenderer 渲染器用于在 3D 场景中渲染纯…...

mongodb文档字符串批量替换

【mongodb文档字符串批量替换脚本语句】 前言&#xff1a; 1、本方式对于数据量大的情况不适用&#xff0c;执行可能比较慢&#xff1b; 2、数据量大的情况&#xff0c;个人推荐代码层面解决&#xff0c;多线程替换更快&#xff1a; &#xff08;1&#xff09;写实体类的方式…...

前端安全和解决方案

提到这个我可能想到的就是不要暴露太多的账号密码信息。一些页面的请求和操作要加上权限。 然后下面就详细的介绍前端可能遇到的安全问题以及解决方法。 首先比较常见的前端的安全性问题就是跨站脚本攻击&#xff08;XSS&#xff09;。跨站请求伪造&#xff08;csrf&#xff…...

Tlias智能辅助学习系统-部门管理

包括查询、新增、删除、修改功能 控制层 package com.itheima.controller;import com.itheima.pojo.Dept; import com.itheima.pojo.Result; import com.itheima.service.DeptService; import lombok.extern.slf4j.Slf4j; import lombok.extern.slf4j.XSlf4j; import org.spr…...

React第十节组件之间传值之context

1、Context 使用creatContext() 和 useContext() Hook 实现多层级传值 概述&#xff1a; 在我们想要每个层级都需要某一属性&#xff0c;或者祖孙之间需要传值时&#xff0c;我们可以使用 props 一层一层的向下传递&#xff0c;或者我们使用更便捷的方案&#xff0c;用 creatC…...

flink中barrier不对齐的原因和影响

Barrier 不对齐&#xff08;Barrier Misalignment&#xff09;可能导致一些性能和一致性相关的问题&#xff0c;但 Flink 提供了机制来确保即使在不对齐的情况下&#xff0c;也可以保证数据的一致性。 1. 什么是 Barrier 不对齐&#xff1f; Barrier 不对齐是指在分布式数据流…...

软银集团孙正义再度加码OpenAI,近屿智能专注AI人才培养

11月28日凌晨&#xff0c;全球最大财经CNBC报道&#xff0c;软银集团创始人兼CEO孙正义再次向人工智能领域的领军企业OpenAI投资了15亿美元。软银对OpenAI的投资已不是首次。就在上个月&#xff0c;软银已在OpenAI的上一轮融资中注入了5亿美元的资金。但他一直寻求获得OpenAI更…...

网站建设规划书目录/住房和城乡建设部

求500万以内的所有亲和数如果两个不同的数a和b&#xff0c;a的所有真因数之和等于b,b的所有真因数之和等于a,则称a,b是一对亲和数。例如220和284&#xff0c;1184和1210&#xff0c;2620和2924。编程实现。 想一想这个问题&#xff0c;首先你要弄清楚&#xff0c;什么是亲和数&…...

坪山网站开发/世界500强企业

冒泡排序的思路是将最大的数或者最小的数移到最右端或者最左端 第一层for循环的意思是一共比较多少趟&#xff0c;第二层for循环的意思是每次需要比较多少次 冒泡排序的时间复杂度是o(n^2) #include<stdio.h>#include<stdlib.h>#define N 100int table[N];void ini…...

网站可以有二维码吗/原版百度

2019独角兽企业重金招聘Python工程师标准>>> 支付宝SDK付款有两种模式&#xff1a;如果外部存在支付宝钱包&#xff0c;则直接跳转到支付宝钱包付款&#xff1b;不存在的场景下&#xff0c;在SDK内部进行H5支付。 1. 数据交互流程 支付宝支付的业务数据交互流程图…...

动态网站建设 毕业答辩/seo网站推广建站服务商

Ndo 的配置方式非常灵活,可以有如下的几种方式 1: 默认的配置方式-单数据库(支持解析SqlClientDriver,OledbDriver,OracleClientDriver,JetDriver,OdbcDriver,SqlOledbDriver,OracleOledbDriver,如果是其它数据源可以通过后面的其它方式)Ndo自动在appSettings 的配置…...

腾讯云wordpress插件/谷歌海外广告投放推广

今年的2月26日&#xff0c;华为在西班牙发布了今年的开年旗舰&#xff1a;P10系列。和P9系列一样&#xff0c;本次的P10系列也依然包括P10和P10 Plus两款机型&#xff0c;相比较前代作品&#xff0c;本次华为P10系列在外观上的改变比较大&#xff0c;而且也加入了全新配色以及全…...

云指网站开发/优化网站搜索排名

调用接口&#xff0c;写个webserver,再调用webserver 接口&#xff1a;http://webservice.webxml.com.cn/WebServices/WeatherWS.asmx 写webserver: [WebMethod(Description "获取江门天气预报")] public string[] WeatherOfJiangMen(string citycode) …...