Qt Xlsx安装教程

Qt Xlsx安装教程

安装perl

如果没有安装perl,请参考perl Window安装教程

下载QtXlsxWriter源码

下载地址

ming32-make编译32 lib库

bash 复制代码
C:\Qt\Qt5.12.12\5.12.12\mingw73_32>d:
D:\>cd D:\Code\QtXlsxWriter-master\QtXlsxWriter-master
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master>cd src
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src 的目录
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>qmake src.pro
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>mingw32-make
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>mingw32-make install

ming32-make编译64 lib库

bash 复制代码
C:\Qt\Qt5.12.12\5.12.12\mingw73_64>d:
D:\>cd D:\Code\QtXlsxWriter-master\QtXlsxWriter-master
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master>cd src
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src 的目录
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>qmake src.pro
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>mingw32-make
D:\Code\QtXlsxWriter-master\QtXlsxWriter-master\src>mingw32-make install

测试读写接口

CMakeLists.txt

bash 复制代码
cmake_minimum_required(VERSION 3.14)

project(TestQtXlsx LANGUAGES CXX)

set(CMAKE_INCLUDE_CURRENT_DIR ON)

set(CMAKE_AUTOUIC ON)
set(CMAKE_AUTOMOC ON)
set(CMAKE_AUTORCC ON)

set(CMAKE_CXX_STANDARD 11)
set(CMAKE_CXX_STANDARD_REQUIRED ON)

find_package(QT NAMES Qt6 Qt5 COMPONENTS Core Xlsx REQUIRED)
find_package(Qt${QT_VERSION_MAJOR} COMPONENTS Core Xlsx REQUIRED)


add_executable(TestQtXlsx
  main.cpp
)
target_link_libraries(TestQtXlsx Qt${QT_VERSION_MAJOR}::Core)
target_link_libraries(TestQtXlsx Qt${QT_VERSION_MAJOR}::Xlsx)

测试代码

cpp 复制代码
#include <QCoreApplication>
#include <QDate>
#include <QTime>
#include <QDebug>
#include "xlsxdocument.h"

static void test_xlsx_write()
{
    //定义一个QXlsx文档对象
    QXlsx::Document xlsx("example.xlsx");

    //设置单元格水平左对齐 垂直居中对齐格式
    QXlsx::Format format;
    format.setHorizontalAlignment(QXlsx::Format::AlignLeft);
    format.setVerticalAlignment(QXlsx::Format::AlignVCenter);

    //写第1列第1行单元格内容
    xlsx.write("A1", "Hello Qt!", format);
    //写第1列第2行单元格内容
    xlsx.write("A2", 12345,format);
    //写第1列第3行单元格内容
    xlsx.write("A3", "=44+33",format);
    //写第1列第4行单元格内容
    xlsx.write("A4", true,format);
    //写第1列第5行单元格内容
    xlsx.write("A5", "http://qt-project.org",format);
    //写第1列第6行单元格内容
    xlsx.write("A6", QDate(2013, 12, 27),format);
    //写第1列第7行单元格内容
    xlsx.write("A7", QTime(6, 30),format);

    //设置行高和列宽
    QXlsx::CellRange range = xlsx.dimension();
    int row = range.rowCount();
    int col = range.columnCount();
    xlsx.setColumnWidth(1,col,30);
    xlsx.setRowHeight(1,row, 20);

    //保存xlsx文件
    xlsx.save();

    return ;
}

static void test_xlsx_read()
{
    //定义一个QXlsx文档对象
    QXlsx::Document xlsx("example.xlsx");

    //读取行列数
    QXlsx::CellRange range = xlsx.dimension();
    int row = range.rowCount();
    int col = range.columnCount();
    qDebug()<<"row="<<row<<"col="<<col;
    
	 //读取第1列第2行内容
    int a2 = xlsx.read("A2").toInt();
    qDebug()<<"A2 content="<<a2;
}

int main(int argc, char *argv[])
{
    QCoreApplication a(argc, argv);

    test_xlsx_write();
    test_xlsx_read();

    return a.exec();
}

测试结果

参考文献:

Qt Xlsx使用教程、Qt操作Excel、Qt生成Excel图表、跨平台不依赖Office
Qt之qtxlsx(Excel读取)开源库使用示例
QtXlsxWriter源码地址

相关推荐
曹勖之26 分钟前
基于ROS2,撰写python脚本,根据给定的舵-桨动力学模型实现动力学更新
开发语言·python·机器人·ros2
豆沙沙包?1 小时前
2025年- H77-Lc185--45.跳跃游戏II(贪心)--Java版
java·开发语言·游戏
军训猫猫头1 小时前
96.如何使用C#实现串口发送? C#例子
开发语言·c#
liuyang-neu1 小时前
java内存模型JMM
java·开发语言
我很好我还能学3 小时前
【面试篇 9】c++生成可执行文件的四个步骤、悬挂指针、define和const区别、c++定义和声明、将引用作为返回值的好处、类的四个缺省函数
开发语言·c++
蓝婷儿3 小时前
6个月Python学习计划 Day 16 - 面向对象编程(OOP)基础
开发语言·python·学习
渣渣盟4 小时前
基于Scala实现Flink的三种基本时间窗口操作
开发语言·flink·scala
糯米导航4 小时前
Java毕业设计:办公自动化系统的设计与实现
java·开发语言·课程设计
糯米导航4 小时前
Java毕业设计:WML信息查询与后端信息发布系统开发
java·开发语言·课程设计
MessiGo4 小时前
Javascript 编程基础(5)面向对象 | 5.1、构造函数实例化对象
开发语言·javascript·原型模式