一、前言

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:x86
lib /def:libxlsxio_read.def /out:libxlsxio_read.lib /machine:x86
lib /def:libxlsxio_readw.def /out:libxlsxio_readw.lib /machine:x86

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

lib /def:libxlsxio_write.def /out:libxlsxio_write.lib /machine:x64
lib /def:libxlsxio_read.def /out:libxlsxio_read.lib /machine:x64
lib /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 <stdio.h>
#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 <stdio.h>
#include<stdlib.h>void 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 <stdio.h>
#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

C语言操作Excel文件相关推荐

  1. c语言从excal读取字符串,C语言操作EXCEL文件(读写)

    C语言操作EXCEL文件(读写) 本文主要介绍通过纯C语言进行EXCEL的读写操作:(修改时间2018.08.28,如果运行结果均是0,请看文章最后一节) C语言读操作 C语言写操作 在之前需要使用C ...

  2. C语言操作EXCEL文件(读写)

    C语言操作EXCEL文件(读写) 本文主要介绍通过纯C语言进行EXCEL的读写操作:(修改时间2018.08.28,如果运行结果均是0,请看文章最后一节) C语言读操作 C语言写操作 在之前需要使用C ...

  3. R语言操作excel文件的数据

    简述 令人惊讶的是,网上的教程关于r语言处理excel数据的都是在说如何读.. 下面以用xlsx这个包为例 安装这个包,并读取数据 [两行命令]R语言读取excel数据 操作数据 其实,导入进来之后, ...

  4. C#在客户端和服务端操作Excel文件

    一.在客户端把数据导入到Excel文件步骤 1.创建Excel application对象,打开或生成Excel文件 //服务端创建StringBuilder对象     System.Text.St ...

  5. C#操作Excel文件(转)

    摘要:本文介绍了Excel对象.C#中的受管代码和非受管代码,并介绍了COM组件在.net环境中的使用. 关键词:受管代码:非受管代码:Excel对象:动态连接库 引言 Excel是微软公司办公自动化 ...

  6. Python操作Excel文件:插入一列数据

    问题描述:已有Excel文件,其中包含5列数据,要求在第3列前插入一列数据,保存为新文件. 参考代码: 运行结果: --------董付国老师Python系列教材-------- 1)<Pyth ...

  7. R语言读取excel文件实战(read.xlsx函数、read_excel函数、read.xlsx函数、Write函数)

    R语言读取excel文件实战(read.xlsx函数.read_excel函数.read.xlsx函数.Write函数) 目录 R语言读取excel文件实战(read.xlsx函数.read_exce ...

  8. python处理excel表格实例-使用Python操作excel文件的实例代码

    使用的类库 pip install openpyxl 操作实现 •工作簿操作 # coding: utf-8 from openpyxl import Workbook # 创建一个excel工作簿 ...

  9. php删除excel文件,php操作excel文件的方法小结

    php操作excel文件的方法小结 php操作excel文件的方法有哪些?就跟随百分网小编一起去了解下吧,想了解更多相关信息请持续关注我们应届毕业生考试网! 一.php,不用COM,生成excel文件 ...

最新文章

  1. 产品经理要读什么书?怎么读?
  2. Python 编程系列
  3. 【转】Cvmat与IplImage的相互转换
  4. JQuery选择器大全
  5. cpu漏洞linux修复,【图片】为什么linux mint上cpu漏洞直到现在也没完全修复?_linux吧_百度贴吧...
  6. zabbix报警收到tcmime.1456.1456.1878.bin附件邮件
  7. 牛刀小试、用SharePoint 实现请假管理功能
  8. mysql 5.5 udf_MYSQL5漏洞之udf提权
  9. 每天一个linux命令(40):wc命令
  10. bzoj2324: [ZJOI2011]营救皮卡丘
  11. ”数独“android小游戏
  12. 【死磕DDD】聊聊领域建模方法论
  13. 计算机445 135 139端口,关闭445 135 137 138 139端口方法图文教程
  14. (83)--用代码实现超越函数
  15. 「Nescafé26」 Freda的传呼机 【最短路径+树上倍增】
  16. wps表格宏被禁用如何解禁_office 2007 禁止宏提示“宏已被禁用”的解决办法
  17. linux流控系统,Linux流量控制(TC)之表面
  18. Point-cloud based 3D object detection and classification methods for self-driving applications
  19. 计算机基础知识学习第一课,第一课计算机基础知识~.ppt
  20. ELK: KQL学习清单

热门文章

  1. Principle安装包
  2. Qt 用 MVD(model view delegate) 模式 把图片变为灰度像素点 [官方Example]
  3. 二叉树的遍历 及求深度、叶子数
  4. RESS南方不动产权籍调查测绘软件,助力房地一体化测量(RESS V20)
  5. 点击button会自动刷新页面??
  6. eyoucm arclist 文档列表
  7. Erasure-Code-擦除码-2-实现篇
  8. git拉取后,代码被覆盖怎么办?
  9. 关于创业及相关的几条微博
  10. 利用Mycat分库分表操作