C语言操作Excel文件
一、前言
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文件相关推荐
- c语言从excal读取字符串,C语言操作EXCEL文件(读写)
C语言操作EXCEL文件(读写) 本文主要介绍通过纯C语言进行EXCEL的读写操作:(修改时间2018.08.28,如果运行结果均是0,请看文章最后一节) C语言读操作 C语言写操作 在之前需要使用C ...
- C语言操作EXCEL文件(读写)
C语言操作EXCEL文件(读写) 本文主要介绍通过纯C语言进行EXCEL的读写操作:(修改时间2018.08.28,如果运行结果均是0,请看文章最后一节) C语言读操作 C语言写操作 在之前需要使用C ...
- R语言操作excel文件的数据
简述 令人惊讶的是,网上的教程关于r语言处理excel数据的都是在说如何读.. 下面以用xlsx这个包为例 安装这个包,并读取数据 [两行命令]R语言读取excel数据 操作数据 其实,导入进来之后, ...
- C#在客户端和服务端操作Excel文件
一.在客户端把数据导入到Excel文件步骤 1.创建Excel application对象,打开或生成Excel文件 //服务端创建StringBuilder对象 System.Text.St ...
- C#操作Excel文件(转)
摘要:本文介绍了Excel对象.C#中的受管代码和非受管代码,并介绍了COM组件在.net环境中的使用. 关键词:受管代码:非受管代码:Excel对象:动态连接库 引言 Excel是微软公司办公自动化 ...
- Python操作Excel文件:插入一列数据
问题描述:已有Excel文件,其中包含5列数据,要求在第3列前插入一列数据,保存为新文件. 参考代码: 运行结果: --------董付国老师Python系列教材-------- 1)<Pyth ...
- R语言读取excel文件实战(read.xlsx函数、read_excel函数、read.xlsx函数、Write函数)
R语言读取excel文件实战(read.xlsx函数.read_excel函数.read.xlsx函数.Write函数) 目录 R语言读取excel文件实战(read.xlsx函数.read_exce ...
- python处理excel表格实例-使用Python操作excel文件的实例代码
使用的类库 pip install openpyxl 操作实现 •工作簿操作 # coding: utf-8 from openpyxl import Workbook # 创建一个excel工作簿 ...
- php删除excel文件,php操作excel文件的方法小结
php操作excel文件的方法小结 php操作excel文件的方法有哪些?就跟随百分网小编一起去了解下吧,想了解更多相关信息请持续关注我们应届毕业生考试网! 一.php,不用COM,生成excel文件 ...
最新文章
- 产品经理要读什么书?怎么读?
- Python 编程系列
- 【转】Cvmat与IplImage的相互转换
- JQuery选择器大全
- cpu漏洞linux修复,【图片】为什么linux mint上cpu漏洞直到现在也没完全修复?_linux吧_百度贴吧...
- zabbix报警收到tcmime.1456.1456.1878.bin附件邮件
- 牛刀小试、用SharePoint 实现请假管理功能
- mysql 5.5 udf_MYSQL5漏洞之udf提权
- 每天一个linux命令(40):wc命令
- bzoj2324: [ZJOI2011]营救皮卡丘
- ”数独“android小游戏
- 【死磕DDD】聊聊领域建模方法论
- 计算机445 135 139端口,关闭445 135 137 138 139端口方法图文教程
- (83)--用代码实现超越函数
- 「Nescafé26」 Freda的传呼机 【最短路径+树上倍增】
- wps表格宏被禁用如何解禁_office 2007 禁止宏提示“宏已被禁用”的解决办法
- linux流控系统,Linux流量控制(TC)之表面
- Point-cloud based 3D object detection and classification methods for self-driving applications
- 计算机基础知识学习第一课,第一课计算机基础知识~.ppt
- ELK: KQL学习清单