读取Excel文件

最近有个需求需要在app内置数据,新来的产品扔给了我两个Excel表格就不管了(两个表格格式还不统一。。。),于是通过度娘等方法找到了Android中读取Excel表格文件的一种方法,记录一下。

闲话一下Excel中工作簿和工作表的区别:

工作簿中包含有工作表。工作簿可以由一张或多张工作表组成,一个工作簿就是一个EXCEL表格文件。

好了,开始读取表格文件吧。

前提

首先,我们假设需要读取的表格文件名字为test.xls, 位于assets根目录下。

所需Jar包

这里为了能读取到Excel表格文件,我们要添加一个第三方Jar包jxl

这里有点儿需要注意的地方:由于表格文件格式较多,老版本的jxl后只支持Excel2003版本的,所以如果拿到的表格文件格式是xlsm或者xlsn之类的,我们首先要把文件另存为xls格式。

开始读取

1.初始化变量:

InputStream inputStream = null;//输入流
FileOutputStream outputStream = null;//输出流 
Workbook book = null;//Excel工作簿对象

2.以流的方式读取我们内置在assets目录下的表格文件

inputStream = context.getAssets().open("test.xls");

3.将上一步的输入流读取成一个文件,方便后续使用

File tempFile = new File(context.getCacheDir(), "test.xls");//临时文件,第二个参数为文件名字,可随便取
outputStream = new FileOutputStream(tempFile);
byte[] buf = new byte[1024];
int len;
while ((len = inputStream.read(buf)) > 0) {//while循环进行读取
outputStream.write(buf, 0, len);
}
outputStream.close();
inputStream.close();

4.得到Excel文件对象后,就可以利用jxl包中提供的各种方法来操作表格文件。jxl提供的方法很多,这里简单介绍下项目中用到的几个。

book = Workbook .getWorkbook(tempFile);//用读取到的表格文件来实例化工作簿对象(符合常理,我们所希望操作的就是Excel工作簿文件)
Sheet[] sheets = book.getSheets(); //得到所有的工作表
for (int m = 0; m < sheets.length; m++) {
Sheet sheet = book.getSheet(m);
int Rows = sheet.getRows();//得到当前工作表的行数
int Cols = sheet.getColumns(); //得到当前工作表的列数
for (int i = 0; i < Cols; i++) {    // 注意:这里是按列读取的!!!
for (int j = 0; j < Rows; j++) {
              String content=sheet.getCell(i, j).getContents();//结果是String类型的,根据具体需求进行类型转换
         }
    }
}

总结

如果表格文件是内置在assets目录下的话,按照以上流程读取即可,如果是在sd卡之类的话,步骤基本一致,都是首先得到我们的表格文件,然后得到工作簿对象,对其进行操作。有需要jxl包的朋友可自行度娘下载,也可以私信我。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Android知识点总结

SpringBoot-13-插曲之Node文件重命名+自动生成json对象

892
来自专栏web开发

JavaScript实现段落文本高亮

代码: <!doctype html> <html lang="en"> <head> <meta http-equiv="Content-Type" ...

1857
来自专栏程序员互动联盟

【专业技术第五讲】动态链接库及其用法

存在的疑惑: 动态链接库到底如何来使用?特别是windows上面 解决方案: 本篇我们讲Windows上的动态链接库(Dynamic Link Library ...

2967
来自专栏林德熙的博客

C# 代码占用的空间

是不是代码会占用空间,如果一个程序初始化需要 100M 的代码,那么在他初始化之后,这些代码就没有作用了,他会不会占空间?本文经过测试发现,代码也是会占空间。

281
来自专栏小李刀刀的专栏

Blade 模板中有关 section 的那些事

Laravel 框架中的 Blade 模板引擎,很好用,但是在官方文档中有关 Blade 的介绍并不详细,有些东西没有写出来,而有些则是没有说清楚。比如,使用中...

3599
来自专栏林冠宏的技术文章

使用 Android Studio 检测内存泄漏与解决内存泄漏问题

本文在腾讯技术推文上 修改 发布。   http://wetest.qq.com/lab/view/63.html?from=ads_test2_qqtip...

1747
来自专栏Jaycekon

Phantomjs+Nodejs+Mysql数据抓取(2.抓取图片)

概要 这篇博客是在上一篇博客Phantomjs+Nodejs+Mysql数据抓取(1.抓取数据) http://blog.csdn.net/jokerko...

3215
来自专栏c#开发者

selenum参考手册中文翻译

Added by SpringSideTeam, last edited by SpringSideTeam on 2006-11-23  (view chan...

2646
来自专栏精讲JAVA

14个你可能不知道的JavaScript调试技巧

以更快的速度和更高的效率来调试JavaScript 熟悉工具可以让工具在工作中发挥出更大的作用。尽管江湖传言 JavaScript 很难调试,但如果你掌握了几个...

1936
来自专栏Java Web

JavaFX-TableView详解

前言 最近在着手一个学生管理系统的编写,涉及到TableView的使用,这前前后后的也有了些经验和想法想要记录和分享一下(事实上我正在想要用html网页代替界面...

3496

扫码关注云+社区