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-8
	char* 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语言库:

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

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

  • 11
    点赞
  • 96
    收藏
    觉得还不错? 一键收藏
  • 5
    评论
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值