一、前言
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