Android读取Excel

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

关于作者demo那里需要自己酌情改动,比如为了使用getResources().openRawResource()获取raw下的表格文件,需要给一个上下文context,作者demo给的是view,结合实际情况修改

 

PS:demo和jar包备份在这:https://download.csdn.net/download/qq_33189961/12720432(给上不了github的同学)

 

 

 

 

 

 

 

Android读取Excel有多种方法,以下是其中两种常用的方法: 1. 使用 Apache POI 库: 首先,将 Apache POI 库添加到您的 Android 项目中。然后,按照以下步骤读取 Excel 文件: a. 创建一个 InputStream 对象,用于打开 Excel 文件: ```java InputStream inputStream = new FileInputStream(filePath); ``` b. 创建一个 Workbook 对象,并根据文件类型进行实例化: ```java Workbook workbook = WorkbookFactory.create(inputStream); ``` c. 获取要读取的工作表对象: ```java Sheet sheet = workbook.getSheetAt(sheetIndex); ``` d. 遍历工作表中的行和列,并读取单元格内容: ```java for (Row row : sheet) { for (Cell cell : row) { String cellValue = cell.getStringCellValue(); // 处理单元格内容 } } ``` e. 关闭 Workbook 和 InputStream: ```java workbook.close(); inputStream.close(); ``` 2. 使用 JExcelApi 库: 首先,将 JExcelApi 库添加到您的 Android 项目中。然后,按照以下步骤读取 Excel 文件: a. 创建一个 Workbook 对象并打开 Excel 文件: ```java Workbook workbook = Workbook.getWorkbook(new File(filePath)); ``` b. 获取要读取的工作表对象: ```java Sheet sheet = workbook.getSheet(sheetIndex); ``` c. 遍历工作表中的行和列,并读取单元格内容: ```java for (int row = 0; row < sheet.getRows(); row++) { for (int col = 0; col < sheet.getColumns(); col++) { Cell cell = sheet.getCell(col, row); String cellValue = cell.getContents(); // 处理单元格内容 } } ``` d. 关闭 Workbook: ```java workbook.close(); ``` 以上是两种常用的方法,您可以根据自己的需求选择适合的方法来读取 Excel 文件。
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值