XLS文件解析库-libxls介绍

embedded/2024/9/25 15:23:00/

1.XLS文件介绍

XLS文件格式是Microsoft Excel早期版本使用的电子表格文件格式。它是由微软为其桌面应用程序Microsoft Excel设计的一种专有文件格式。
XLS:最初在1993年与Excel 4.0一起推出,后来在Excel 5.0至Excel 2003的各个版本中得到了进一步的发展。
由于项目需要,需要解析XLS格式的文件,新的开源库有的是不支持解析XLS文件的,主要是支持xlsl的文件。

2.配置环境

下载地址:https://github.com/libxls/libxls
特点:这是libxls,一个用于读取旧二进制OLE格式Excel文件的C库,还有一个用于将XLS转换为CSV的命令行工具(恰如其分地命名为xls2csv)、跨平台。

使用:我这里直接将源码引用到我的工程中。
在这里插入图片描述
这里为了方便,还专门提供了C++接口。
在这里插入图片描述

3.使用

C语言使用如下所示。

xls_error_t error = LIBXLS_OK;
xlsWorkBook *wb = xls_open_file("/path/to/finances.xls", "UTF-8", &error);
if (wb == NULL) {printf("Error reading file: %s\n", xls_getError(error));exit(1);
}
for (int i=0; i<wb->sheets.count; i++) { // sheetsxlsWorkSheet *work_sheet = xls_getWorkSheet(work_book, i);error = xls_parseWorkSheet(work_sheet);for (int j=0; j<=work_sheet->rows.lastrow; j++) { // rowsxlsRow *row = xls_row(work_sheet, j);for (int k=0; k<=work_sheet->rows.lastcol; k++) { // columnsxlsCell *cell = &row->cells.cell[k];// do something with cellif (cell->id == XLS_RECORD_BLANK) {// do something with a blank cell} else if (cell->id == XLS_RECORD_NUMBER) {// use cell->d, a double-precision number} else if (cell->id == XLS_RECORD_FORMULA) {if (strcmp(cell->str, "bool") == 0) {// its boolean, and test cell->d > 0.0 for true} else if (strcmp(cell->str, "error") == 0) {// formula is in error} else {// cell->str is valid as the result of a string formula.}} else if (cell->str != NULL) {// cell->str contains a string value}}}xls_close_WS(work_sheet);
}
xls_close_WB(wb);

C++使用如下所示:

#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cctype>
#include <cassert>#include "XlsReader.h"using namespace xls;
using namespace std;int main(int argc, char *argv[])
{if(argc < 2) {printf("Usage: test_cpp <file.xls>\n");exit(1);}string s = string(argv[1]);WorkBook foo(s);cellContent cell = foo.GetCell(0, 1, 2);foo.ShowCell(cell);for(int sheetNum = 0; sheetNum < foo.GetSheetCount(); ++sheetNum) {if(sheetNum) printf("\n\n");printf("===>>> SheetName: %s\n\n", foo.GetSheetName(sheetNum).c_str());foo.InitIterator(sheetNum);while(true) {cellContent c = foo.GetNextCell();if(c.type == cellBlank) break;foo.ShowCell(c);}}
}

http://www.ppmy.cn/embedded/105735.html

相关文章

【前端】中断请求的方式

一 使用 Axios 和取消令牌 1.步骤: 初始化取消源,创建CancelToken const source axios.CancelToken.source();传递cancelToken, 发起请求 axios.get(/api/data, {cancelToken: source.token });触发取消请求 source.cancel(操作被取消);判断错误是否由于取消请求操作引起…

godot开发初体验

点击加号可以创建一个新的场景 点击其它节点可以添加节点 想对某个节点添加子节点可以右键这个节点,然后点击添加子节点 在左下角的文件系统中,可以右键某个场景,并将其设置为主场景,主场景作为程序的入口 点击项目->项目设置-> 输入映射,可以添加一个新的动作,在添加新动…

NVIDIA GPU atom.global指令Profing

NVIDIA GPU atom.global指令Profing 一.小结二.输出解释三.复现过程 本文对NVIDIA GPU atom.global指令Profing,并小结 一.小结 sm atom指令的执行能力为:112 inst/cycle,每条atom warp指令会产生32个request,即3584 request/cyclelts有18个slice,每个slice处理能力为 1 requ…

无人机反制:无线电侦测设备技术详解

无人机反制技术中的低空安全综合管理平台&#xff0c;作为守护低空安全的重要工具&#xff0c;集成了多种先进的技术手段和管理功能&#xff0c;实现了对无人机等低空飞行器的全方位、无死角监控与反制。以下是对该技术平台的详细解析&#xff1a; 一、技术架构与核心功能 低…

Android Audio基础——音频模式设置(十九)

在《音频属性设是置》中介绍使用 setParameters 设置音频属性时,就是以设置音频模式及为例进行讲解的,其实在 AudioManager 中同样存在一个接口用来设置音频模式的,这里我们就来看一下。 一、音频模式 1、基础介绍 音频模式对于控制不同场景下的音频输出是非常有用的。 模…

怎么检测电脑的RAM?丨什么是RAM?

RAM 是 Random Access Memory 的缩写&#xff0c;它是一个允许计算机短期存储数据以更快访问的组件。众所周知&#xff0c;操作系统、应用程序和各种个人文件都存储在硬盘驱动器中。 当 CPU 需要调用硬盘上的数据进行计算和运行时&#xff0c;CPU 会将数据传输到 RAM 中进行计…

docker Desktop报错 error pulling image configuration 处理

问题描述 在 docker 拉数据 出现以下错误 error pulling image configurarion&#xff1a; 这个问题 主要是 可能应该某些原因不能网络无法连上镜像 原因分析&#xff1a; 1。 2024年 5月以后 国内很多IP都 。。。懂的都懂&#xff0c;很多 VPN 也是。。。 懂的都懂&#x…

SQLite3 数据类型深入全面讲解

SQLite3&#xff0c;作为一款轻量级的数据库管理系统&#xff0c;在数据存储方面展现出了其独特的魅力。它不仅支持标准的SQL语法&#xff0c;还提供了丰富的数据类型供开发者选择。这些数据类型不仅涵盖了基本的数值和文本类型&#xff0c;还包括了日期时间、二进制数据等复杂…