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源码地址

相关推荐
纵有疾風起4 小时前
C++—string(1):string类的学习与使用
开发语言·c++·经验分享·学习·开源·1024程序员节
Molesidy4 小时前
【随笔】【QT】QT5.15.2版本的最新下载方式!!!
开发语言·qt
梨轻巧5 小时前
pyside6的历史发展、Qt 介绍、PyQt 和 pyside6对比
qt·pyqt
二进制person5 小时前
Java EE初阶 --多线程2
java·开发语言
yue0085 小时前
C#理论学习-WinForm实践开发教程总结
开发语言·学习·c#
007php0076 小时前
某游戏大厂 Java 面试题深度解析(四)
java·开发语言·python·面试·职场和发展·golang·php
Mr.Jessy6 小时前
Web APIs学习第一天:获取 DOM 对象
开发语言·前端·javascript·学习·html
午安~婉6 小时前
javaScript八股问题
开发语言·javascript·原型模式
想不明白的过度思考者6 小时前
Rust——异步递归深度指南:从问题到解决方案
开发语言·后端·rust
芝麻开门-新起点7 小时前
flutter 生命周期管理:从 Widget 到 State 的完整解析
开发语言·javascript·ecmascript