目的
就是利用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