XLS文件解析库-libxls介绍

2024-09-04 22:44
文章标签 介绍 解析 xls libxls

本文主要是介绍XLS文件解析库-libxls介绍,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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);}}
}

这篇关于XLS文件解析库-libxls介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137247

相关文章

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

java中的HashSet与 == 和 equals的区别示例解析

《java中的HashSet与==和equals的区别示例解析》HashSet是Java中基于哈希表实现的集合类,特点包括:元素唯一、无序和可包含null,本文给大家介绍java中的HashSe... 目录什么是HashSetHashSet 的主要特点是HashSet 的常用方法hasSet存储为啥是无序的

四种Flutter子页面向父组件传递数据的方法介绍

《四种Flutter子页面向父组件传递数据的方法介绍》在Flutter中,如果父组件需要调用子组件的方法,可以通过常用的四种方式实现,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录方法 1:使用 GlobalKey 和 State 调用子组件方法方法 2:通过回调函数(Callb

Linux中shell解析脚本的通配符、元字符、转义符说明

《Linux中shell解析脚本的通配符、元字符、转义符说明》:本文主要介绍shell通配符、元字符、转义符以及shell解析脚本的过程,通配符用于路径扩展,元字符用于多命令分割,转义符用于将特殊... 目录一、linux shell通配符(wildcard)二、shell元字符(特殊字符 Meta)三、s

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

java脚本使用不同版本jdk的说明介绍

《java脚本使用不同版本jdk的说明介绍》本文介绍了在Java中执行JavaScript脚本的几种方式,包括使用ScriptEngine、Nashorn和GraalVM,ScriptEngine适用... 目录Java脚本使用不同版本jdk的说明1.使用ScriptEngine执行javascript2.

Python实现NLP的完整流程介绍

《Python实现NLP的完整流程介绍》这篇文章主要为大家详细介绍了Python实现NLP的完整流程,文中的示例代码讲解详细,具有一定的借鉴价值,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1. 编程安装和导入必要的库2. 文本数据准备3. 文本预处理3.1 小写化3.2 分词(Tokenizatio

使用Python实现批量访问URL并解析XML响应功能

《使用Python实现批量访问URL并解析XML响应功能》在现代Web开发和数据抓取中,批量访问URL并解析响应内容是一个常见的需求,本文将详细介绍如何使用Python实现批量访问URL并解析XML响... 目录引言1. 背景与需求2. 工具方法实现2.1 单URL访问与解析代码实现代码说明2.2 示例调用

SSID究竟是什么? WiFi网络名称及工作方式解析

《SSID究竟是什么?WiFi网络名称及工作方式解析》SID可以看作是无线网络的名称,类似于有线网络中的网络名称或者路由器的名称,在无线网络中,设备通过SSID来识别和连接到特定的无线网络... 当提到 Wi-Fi 网络时,就避不开「SSID」这个术语。简单来说,SSID 就是 Wi-Fi 网络的名称。比如

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R