当前位置: 首页 > 编程笔记 >

Android 中读取Excel文件实例详解

蔚楷
2023-03-14
本文向大家介绍Android 中读取Excel文件实例详解,包括了Android 中读取Excel文件实例详解的使用技巧和注意事项,需要的朋友参考一下

Android 中读取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卡之类的话,步骤基本一致,都是首先得到我们的表格文件,然后得到工作簿对象,对其进行操作。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

 类似资料:
  • 本文向大家介绍python读取Excel实例详解,包括了python读取Excel实例详解的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了python读取Excel实例的具体代码,供大家参考,具体内容如下 1.操作步骤: (1)安装python官方Excel库-->xlrd (2)获取Excel文件位置并读取 (3)读取sheet (4)读取指定rows和cols内容 2.示例代码:

  • 本文向大家介绍Java 读取excel 文件流代码实例,包括了Java 读取excel 文件流代码实例的使用技巧和注意事项,需要的朋友参考一下 这篇文章主要介绍了Java 读取excel 文件流代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 代码如下 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持呐喊教程。

  • 本文向大家介绍java 读取本地文件实例详解,包括了java 读取本地文件实例详解的使用技巧和注意事项,需要的朋友参考一下 java 读取本地文件实例详解 用javax.xml、w3c解析 实例代码: 用dom4j解析 感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

  • 本文向大家介绍详解pandas库pd.read_excel操作读取excel文件参数整理与实例,包括了详解pandas库pd.read_excel操作读取excel文件参数整理与实例的使用技巧和注意事项,需要的朋友参考一下 除了使用xlrd库或者xlwt库进行对excel表格的操作读与写,而且pandas库同样支持excel的操作;且pandas操作更加简介方便。 首先是pd.read_excel

  • 本文向大家介绍PHPExcel简单读取excel文件示例,包括了PHPExcel简单读取excel文件示例的使用技巧和注意事项,需要的朋友参考一下 本文实例讲述了PHPExcel简单读取excel文件的方法。分享给大家供大家参考,具体如下: PHP Excel 2007 classes Project providing a set of classes for the PHP programmi

  • 本文向大家介绍C++读取INI配置文件类实例详解,包括了C++读取INI配置文件类实例详解的使用技巧和注意事项,需要的朋友参考一下 本文以实例讲解了C++读取配置文件的方法。 一般情况下,我们都喜欢使用ini扩展名的文件作为配置文件,可以读取及修改变量数值,也可以设置新的组,新的变量,本文的实例代码一个是读取INI的定义文件,另一个是CIniFile类实现文件,两者结合,完美实现VC++对INI文