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

相关文章

Java 正则表达式URL 匹配与源码全解析

《Java正则表达式URL匹配与源码全解析》在Web应用开发中,我们经常需要对URL进行格式验证,今天我们结合Java的Pattern和Matcher类,深入理解正则表达式在实际应用中... 目录1.正则表达式分解:2. 添加域名匹配 (2)3. 添加路径和查询参数匹配 (3) 4. 最终优化版本5.设计思

使用Java将DOCX文档解析为Markdown文档的代码实现

《使用Java将DOCX文档解析为Markdown文档的代码实现》在现代文档处理中,Markdown(MD)因其简洁的语法和良好的可读性,逐渐成为开发者、技术写作者和内容创作者的首选格式,然而,许多文... 目录引言1. 工具和库介绍2. 安装依赖库3. 使用Apache POI解析DOCX文档4. 将解析

Java字符串处理全解析(String、StringBuilder与StringBuffer)

《Java字符串处理全解析(String、StringBuilder与StringBuffer)》:本文主要介绍Java字符串处理全解析(String、StringBuilder与StringBu... 目录Java字符串处理全解析:String、StringBuilder与StringBuffer一、St

Spring Boot循环依赖原理、解决方案与最佳实践(全解析)

《SpringBoot循环依赖原理、解决方案与最佳实践(全解析)》循环依赖指两个或多个Bean相互直接或间接引用,形成闭环依赖关系,:本文主要介绍SpringBoot循环依赖原理、解决方案与最... 目录一、循环依赖的本质与危害1.1 什么是循环依赖?1.2 核心危害二、Spring的三级缓存机制2.1 三

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

MySQL中FIND_IN_SET函数与INSTR函数用法解析

《MySQL中FIND_IN_SET函数与INSTR函数用法解析》:本文主要介绍MySQL中FIND_IN_SET函数与INSTR函数用法解析,本文通过实例代码给大家介绍的非常详细,感兴趣的朋友一... 目录一、功能定义与语法1、FIND_IN_SET函数2、INSTR函数二、本质区别对比三、实际场景案例分

Pytest多环境切换的常见方法介绍

《Pytest多环境切换的常见方法介绍》Pytest作为自动化测试的主力框架,如何实现本地、测试、预发、生产环境的灵活切换,本文总结了通过pytest框架实现自由环境切换的几种方法,大家可以根据需要进... 目录1.pytest-base-url2.hooks函数3.yml和fixture结论你是否也遇到过

Java图片压缩三种高效压缩方案详细解析

《Java图片压缩三种高效压缩方案详细解析》图片压缩通常涉及减少图片的尺寸缩放、调整图片的质量(针对JPEG、PNG等)、使用特定的算法来减少图片的数据量等,:本文主要介绍Java图片压缩三种高效... 目录一、基于OpenCV的智能尺寸压缩技术亮点:适用场景:二、JPEG质量参数压缩关键技术:压缩效果对比

关于WebSocket协议状态码解析

《关于WebSocket协议状态码解析》:本文主要介绍关于WebSocket协议状态码的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录WebSocket协议状态码解析1. 引言2. WebSocket协议状态码概述3. WebSocket协议状态码详解3

CSS Padding 和 Margin 区别全解析

《CSSPadding和Margin区别全解析》CSS中的padding和margin是两个非常基础且重要的属性,它们用于控制元素周围的空白区域,本文将详细介绍padding和... 目录css Padding 和 Margin 全解析1. Padding: 内边距2. Margin: 外边距3. Padd