POI,是如今比较主流的处理office文档的框架,可以导入也可以生成,缺点是:官方的依赖包的体积较大,官方最新版本在android项目所需sdk需要minSDK 24及以上。
最后找到的一个比较轻便简单的方案是,通过一个国外的开发者对POI包进行简化后的库android5xlsx,保留了在Android5以上解析xls和xlsx的功能,详细用法可以去看官方文档或者作者的demo,
一、解除 65 K :
在build.gradle(app)下添加 multiDexEnabled true
二、将android5xlsx的核心的两个jar包导入项目lib文件夹
demo
1、在res/row下放上test.xslx
====>
2、代码如下:
public void readExcel(Context context) {
InputStream stream = context.getResources().openRawResource(R.raw.test);
try {
XSSFWorkbook workbook = new XSSFWorkbook(stream);
XSSFSheet sheet = workbook.getSheetAt(0);//sheet
int rowsCount = sheet.getPhysicalNumberOfRows();//行数
System.out.println("行数:"+rowsCount);
FormulaEvaluator formulaEvaluator = workbook.getCreationHelper().createFormulaEvaluator();
for (int r = 0; r<rowsCount; r++) {
Row row = sheet.getRow(r);//行
int cellsCount = row.getPhysicalNumberOfCells();//每行单元格数
System.out.println("单元格数:"+cellsCount);
for (int c = 0; c<cellsCount; c++) {
System.out.println("结果"+row.getCell(c).getNumericCellValue());
}
}
} catch (Exception e) {
/* proper exception handling to be here */
System.out.println("proper exception 。。。");
}
}
结果:
关于作者demo那里需要自己酌情改动,比如为了使用getResources().openRawResource()获取raw下的表格文件,需要给一个上下文context,作者demo给的是view,结合实际情况修改
PS:demo和jar包备份在这:https://download.csdn.net/download/qq_33189961/12720432(给上不了github的同学)