一、前言

xlsxio是一个用用于读写 .xlsx 文件的 C 库,其github地址如下:

https://github.com/brechtsanders/xlsxio

该库的编写考虑了以下目标:

  • 用标准 C 编写,但允许由 C++ 使用
  • 简单的界面
  • 占地面积小
  • 可跨不同平台移植(Windows、*nix)
  • 最小的依赖性:只依赖于 expat(只用于阅读)和 minizip 或 libzip(它们又依赖于 zlib)
  • 用于读取和写入 .xlsx 文件的独立库
  • 不需要安装 Microsoft(R) Excel(TM)

读取 .xlsx 文件:

  • 旨在将 .xlsx 文件作为数据表处理,它假定以下内容:
    • 假定第一行包含标题名称
    • 假定下一行包含与提供标题名称的列相同的列中的值
    • 仅处理值,忽略其他任何内容(公式、布局、图形、图表…)
  • 整个共享字符串表都加载到内存中(警告:对于具有很多不同值的大型电子表格来说可能很大)
  • 支持没有共享字符串表的 .xlsx 文件
  • 工作表数据本身是即时读取的,无需在内存中缓冲数据
  • 提供2个方法
    • 一种允许应用程序遍历行和单元格的简单方法
    • 一种高级方法(开销较小),它为每个单元格和每一行之后调用回调函数

编写 .xlsx 文件:

  • 用于将数据表编写为 .xlsx 文件,它假定以下内容:
    • 仅支持写入数据(不支持公式、布局、图形、图表…)
    • 不支持多个工作表(每个文件只有一个工作表)
  • 即时生成文件,无需在内存中缓冲数据
  • 不支持共享字符串(所有值都写为内联字符串)

二、库的下载

方式一

我已将文件打包上传至CSDN:

32位:https://download.csdn.net/download/hfy1237/87630603

64位:https://download.csdn.net/download/hfy1237/87630617

方式二

也可以下载官方已编译好的二进制文件,如下:

Releases · brechtsanders/xlsxio · GitHub

由于官方是在MSYS2 shell 下使用 MinGW-w64 构建的二进制文件,如果需要使用MSVC进行编译链接,则需要编译生成对应的 .lib 文件,具体方法如下:

Step1 打开 Developer Command Prompt for VS2022

Step2 进入下载好的文件的 lib 文件夹下

Step3 执行命令

如果你下载的32位包,请执行以下代码

lib /def:libxlsxio_write.def /out:libxlsxio_write.lib /machine:x86lib /def:libxlsxio_read.def /out:libxlsxio_read.lib /machine:x86lib /def:libxlsxio_readw.def /out:libxlsxio_readw.lib /machine:x86

如果你下载的64位包,请执行以下代码

lib /def:libxlsxio_write.def /out:libxlsxio_write.lib /machine:x64lib /def:libxlsxio_read.def /out:libxlsxio_read.lib /machine:x64lib /def:libxlsxio_readw.def /out:libxlsxio_readw.lib /machine:x64

三、使用

新建VS工程项目,并添加对应的

  • 头文件目录
    • include
  • 库文件目录
    • lib
  • 库文件
    • libxlsxio_read.lib
    • libxlsxio_readw.lib
    • libxlsxio_write.lib

然后在将bin文件夹下的 .dll 文件添加到生成可执行程序所在文件夹下。

四、读取Excel文件

测试文件的内容如下:

#define _CRT_SECURE_NO_WARNINGS#include #include "xlsxio_read.h"int main(){//打开 .xlsx文件xlsxioreader xlsxioread;if ((xlsxioread = xlsxioread_open("../test.xlsx")) == NULL) {fprintf(stderr, "Error opening .xlsx file\n");return 1;}//从第一个表单读取值char* value;xlsxioreadersheet sheet;const char* sheetname = NULL;printf("第一个表单得内容为:\n");printf("-------------------------------\n");if ((sheet = xlsxioread_sheet_open(xlsxioread, sheetname, XLSXIOREAD_SKIP_EMPTY_ROWS)) != NULL) {// 读取所有行while (xlsxioread_sheet_next_row(sheet)) {//读取所有列while ((value = xlsxioread_sheet_next_cell(sheet)) != NULL) {printf("%s\t", value);xlsxioread_free(value);}printf("\n");}xlsxioread_sheet_close(sheet);}printf("-------------------------------\n");printf("读取完成\n");// 清理内存xlsxioread_close(xlsxioread);}

运行结果如下:

由于编码原因,读取结果显示乱码,需要设置控制台的编码方式为 utf-8 其中一种解决方案如下:

#define _CRT_SECURE_NO_WARNINGS#include "xlsxio_read.h"#include #includevoid read_test(){//打开.xlsx文件xlsxioreader xlsxioread;if ((xlsxioread = xlsxioread_open("../test.xlsx")) == NULL) {fprintf(stderr, "Error opening .xlsx file\n");return 1;}//从第一个表单读取值system("chcp 65001"); // 设置命令行窗口的编码方式为utf-8char* value;xlsxioreadersheet sheet;const char* sheetname = NULL;printf(u8"第一个表单得内容为:\n");printf("-------------------------------\n");if ((sheet = xlsxioread_sheet_open(xlsxioread, sheetname, XLSXIOREAD_SKIP_EMPTY_ROWS)) != NULL) {// 读取所有行while (xlsxioread_sheet_next_row(sheet)) {//读取当前行的所有列while ((value = xlsxioread_sheet_next_cell(sheet)) != NULL) {printf("%s测试\t", value);xlsxioread_free(value);}printf("\n");}xlsxioread_sheet_close(sheet);}printf("-------------------------------\n");printf(u8"读取完成\n");// 关闭.xlsx文件xlsxioread_close(xlsxioread);}void txt_read(){char buff[255];FILE* fp = NULL;fp = fopen("test.txt", "r");fscanf(fp, "%s", buff);printf("1: %s\n", buff);fclose(fp);}int main(){//txt_read();read_test();}

运行结果如下:

五、生成Excel文件

#define _CRT_SECURE_NO_WARNINGS#include #include "xlsxio_write.h"int main(){//打开.xlsx文件xlsxiowriter handle;if ((handle = xlsxiowrite_open("../a.xlsx", "MySheet")) == NULL) {fprintf(stderr, "Error creating .xlsx file\n");return 1;}//写入列名xlsxiowrite_add_column(handle, "Col1", 16);xlsxiowrite_add_column(handle, "Col2", 0);xlsxiowrite_next_row(handle);//写入数据int i;for (i = 0; i < 1000; i++) {xlsxiowrite_add_cell_string(handle, "Test");xlsxiowrite_add_cell_int(handle, i);xlsxiowrite_next_row(handle);}//关闭.xlsx文件xlsxiowrite_close(handle);}

如果需要写入中文,需要字符串前添加 u8 标识

例如:

六、附录

其他读取 excel 的C语言库:

  • libxlsxwriter:libxlsxwriter: Creating Excel files with C and libxlsxwriter
  • libxls:GitHub – libxls/libxls: Read binary Excel files from C/C++
  • xlslib:GitHub – JanX2/xlslib: C++/C library to construct Excel .xls files
  • libxl:C++ Excel Library to read/write xls/xlsx files – LibXL

C语言读取 Excel 较为麻烦,建议使用 Python 来进行读写。

参考:http://t.csdn.cn/o4fRJ