Android创建保存Excel文件

Android开发生成保存Excel文件,首先下载两个jar包。下载地址:Android读写Excel文件的两个jar包资源-CSDN文库

poi-3.12-android-a.jar

poi-ooxml-schemas-3.12-20150511-a.jar

把jar包放在app的libs文件夹下,引用jar我一般都在build.gradle的dependencies中添加

implementation fileTree(dir: "libs", include: ["*.?ar"])

把.jar和.aar都引用上。

如果项目需要混淆,则加上混淆

#生成Excel
-keep class com.bea.xml.stream.** { *;}
-keep class com.wutka.dtd.** { *;}
-keep class org.** { *;}
-keep class aavax.xml.** { *;}
-keep class com.microsoft.schemas.office.x2006.** { *; }
-keep class schemaorg_apache_xmlbeans.** { *; }
-keep class schemasMicrosoftComOfficeExcel.** { *; }
-keep class schemasMicrosoftComOfficeOffice.** { *; }
-keep class schemasMicrosoftComVml.** { *; }
-keep class repackage.** { *; }
-keep class schemaorg_apache_xmlbeans.** { *; }

然后就是生成Excel文件了

/**
     * 创建excel分析结果文件
     */
    private void createExcel(){
        new Thread(){
            @Override
            public void run() {
                try {
                    Log.i("lllllll", "createExcel  ======");
                    XSSFWorkbook workbook = new XSSFWorkbook();
                    XSSFSheet sheet = workbook.createSheet(WorkbookUtil.createSafeSheetName("sheet"));
                    //第一行
                    Row row0 = sheet.createRow(0);
                    String[] title = new String[]{"市公司", "道路名称", "路段长度(米)", "计算值", "起始经纬度", "结束经纬度"};
                    for (int i= 0;i<title.length;i++){
                        Cell cell = row0.createCell(i);
                        cell.setCellValue(title[i]);
                    }
                    //添加数据
                    for (int i= 0;i<excelBeans.size();i++){
                        ExcelBean eb = excelBeans.get(i);
                        Row row = sheet.createRow(i+1);
                        for (int j= 0;j<title.length;j++){
                            Cell cell = row.createCell(j);
                            if (j == 0){
                                cell.setCellValue(eb.getCity());
                            }else if (j == 1){
                                cell.setCellValue(eb.getAddress());
                            }else if (j == 2){
                                double distance = DistanceUtil.getDistance(eb.getStartLatLng(), eb.getStopLatLng());
                                cell.setCellValue(NumberUtils.makeNumDecimalPlaces(distance, 2));
                            }else if (j == 3){
                                cell.setCellValue(eb.getCoverage());
                            }else if (j == 4){
                                cell.setCellValue("["+eb.getStartLatLng().longitude + ","+eb.getStartLatLng().latitude+"]");
                            }else if (j == 5){
                                cell.setCellValue("["+eb.getStopLatLng().longitude + ","+eb.getStopLatLng().latitude+"]");
                            }
                        }
                    }

                    String path = parseFile.getAbsolutePath();
                    SimpleDateFormat dateFormat = new SimpleDateFormat("yyyyMMdd-HHmmss");
                    String time = dateFormat.format(new Date());
                    analysisFilePath = path.replace(".csv", "_analysis_"+earfcn+"_"+time+".xlsx");
                    Log.i("lllllll", "fileName  ======" +analysisFilePath);
                    FileOutputStream fos = new FileOutputStream(analysisFilePath);
                    workbook.write(fos);
                    fos.flush();
                    fos.close();

                    Log.i("lllllll", "保存成功  ======");
                }catch (Exception e){
                    e.printStackTrace();
                }
            }
        }.start();
    }

我这生成Excel之后,在手机里能打开,但是在电脑上只能用WPS打开,用offic打开就会报错。我查了半天,最终没有找到问题在哪。有可能是我电脑上的offic版本太低了,不过WPS能打开已经能满足需求了。

相关推荐

  1. Android创建保存Excel文件

    2024-01-27 20:12:01       34 阅读
  2. Android 生成Excel文件保存到本地

    2024-01-27 20:12:01       22 阅读
  3. 融资项目——EasyExcel将Excel文件保存至数据库

    2024-01-27 20:12:01       35 阅读
  4. C#使用NPOI保存DataGridView数据到EXCEL文件

    2024-01-27 20:12:01       21 阅读
  5. 用Python实现批量创建Excel文件

    2024-01-27 20:12:01       34 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-27 20:12:01       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-27 20:12:01       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-27 20:12:01       19 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-27 20:12:01       20 阅读

热门阅读

  1. html:thymeleaf实现日期格式转换

    2024-01-27 20:12:01       51 阅读
  2. Web开发:AES加密解密的demo

    2024-01-27 20:12:01       32 阅读
  3. 开源模型应用落地-业务优化篇(一)

    2024-01-27 20:12:01       47 阅读
  4. 蓝桥杯-4999小蓝的能源挑战(c/c++)

    2024-01-27 20:12:01       33 阅读
  5. 什么是银行虚拟账户,银行云账户有什么用?

    2024-01-27 20:12:01       64 阅读
  6. 创建django项目

    2024-01-27 20:12:01       45 阅读
  7. 【arxiv加载慢的解决方法】

    2024-01-27 20:12:01       36 阅读
  8. LeetCode85. Maximal Rectangle——单调栈

    2024-01-27 20:12:01       27 阅读
  9. 力扣:98. 验证二叉搜索树

    2024-01-27 20:12:01       33 阅读