本文主要是介绍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介绍的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!