java poi 导入导出多个sheet 的excel数据

 

pulic class excelUtil{

   

/**
     * 数据导入到excel
     */
     public static void importData(filePath){
        HSSFWorkbook workbook=new HSSFWorkbook(new FileInputStream(new File(filePath)));
        HSSFSheet sheet=null;
//        List<String> sheetNameList = new ArrayList<>();
        List<List<List<String>>> listData = new ArrayList<>();
        for (int i = 0; i < workbook.getNumberOfSheets(); i++) {//获取每个Sheet表
//            sheetNameList.add(workbook.getSheetName(i));
             sheet=workbook.getSheetAt(i);
             List<List<String>> sheetList = new ArrayList<>();
             for (int j = 0; j < sheet.getPhysicalNumberOfRows(); j++) {//获取每行
                HSSFRow row=sheet.getRow(j);
                List<String> rowList = new ArrayList<String>();
                for (int k = 0; k < row.getPhysicalNumberOfCells(); k++) {//获取每个单元格
                    rowList.add(String.valueOf(row.getCell(k)));
                }
                sheetList.add(rowList);
            }
             System.out.println("---Sheet表"+i+"数据:"+sheetList);
             listData.add(sheetList);
        }
        System.out.println("---所有数据:"+listData);
//        System.out.println("---sheetName:"+sheetNameList);
    }
    /**
     * 数据导出到excel
     */
    public static void exportData(List<List<Map<String,Object>>> listObj,OutPutStream out,String[] sheetName ){
        try {
            //创建对象
            HSSFWorkbook workbook = new HSSFWorkbook();
            for (int i = 0; i < listObj.size(); i++) {
                //创建sheet
                HSSFSheet sheet = workbook.createSheet(sheetName[i]);
                
                HSSFRow row = sheet.createRow(0);
                //设置excel第一行
                Map<String,Object> map = listObj.get(i).get(0);
                int column = 0;
                for(Map.Entry<String, Object> map : map.entrySet()){
                    HSSFCell cell = row.createCell(column++);
                    cell.setCellValue(entry.getKey());
                }
                //添加数据
                for (int j = 0; j < listObj.get(i).size(); j++) {
                    HSSFRow  row2 = sheet.createRow(1+j);
                    int columnValue = 0;
                    for(Map.Entry<String, Object> entry : listObj.get(i).get(j).entrySet()){
                        HSSFCell cell2 = row2.createCell(columnValue++);
                        if(entry.getValue() ! = null ){
                            cell2.setCellValue(String.valueOf(entry.getValue()));
                        }else{
                            cell2.setCellValue("");
                        }
                    }
                }
            }
            workbook.write(out);
            workbook.close;
        } catch (Exception e) {
            e.printStackTrace();
        }
    }

 

 

}

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值