美文网首页java学习之路
java使用poi导出实现单元格合并

java使用poi导出实现单元格合并

作者: 唯有努力不欺人丶 | 来源:发表于2020-06-08 10:28 被阅读0次

    额,单纯的一个记录贴。因为最近做模板导出这个格式比较多变。所以涉及到了单元格合并。这里简单的记录一下:
    首先poi中单元格合并的方法:

    sheet.addMergedRegion(new CellRangeAddress(i, i + temp, j, j));
    

    重点是这个方法是四个参数:首先我们知道所谓的单元格合并就是多个单元格合成一个,不管是想怎么合,最终出来的也都是方形是单元格,这个很好理解吧?方形的单元格就有起始格点的。


    合并单元格

    如图中的红色框框其实就是上下两个单元格合并的。
    继续说这个合并单元格的方法参数:第一个参数是合并后单元格的最上面的横坐标,第二个参数是合并后单元格的最下面的横坐标。比如我途中红色框框是1,2.
    第三个参数是合并后单元格的最左边的纵坐标。第四个参数是最右边的纵坐标,
    然后值的话,会采用左上角的那个格子的值覆盖(不过一般合并单元格的前提一般都是值相同的才有必要合并)。
    下面是具体的实现:

    public class PoiUtil {
        
        public static HSSFWorkbook getHSSFWorkbook(List<SysOrder> list){
    
    
            // 第一步,创建一个HSSFWorkbook,对应一个Excel文件
            HSSFWorkbook wb = new HSSFWorkbook();
    
            // 第二步,在workbook中添加一个sheet,对应Excel文件中的sheet
            HSSFSheet sheet = wb.createSheet();
    
            // 第三步,在sheet中添加表头第0行,注意老版本poi对Excel的行数列数有限制
            HSSFRow row = sheet.createRow(0);
    
            // 第四步,创建单元格,并设置值表头 设置表头居中
            HSSFCellStyle style = wb.createCellStyle();
    
    
    
            style.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 创建一个居中格式
    
    
            HSSFCell cell1 = row.createCell(0);
            cell1.setCellValue("订单号");
            cell1.setCellStyle(style);
    
            HSSFCell cell2 = row.createCell(1);
            cell2.setCellValue("店铺名称");
            cell2.setCellStyle(style);
    
            HSSFCell cell6 = row.createCell(5);
            cell6.setCellValue("备注");
            cell6.setCellStyle(style);
    
            HSSFCell cell7 = row.createCell(6);
            cell7.setCellValue("订单价格");
            cell7.setCellStyle(style);
    
            HSSFCell cell8 = row.createCell(7);
            cell8.setCellValue("优惠券");
            cell8.setCellStyle(style);
    
            HSSFCell cell9 = row.createCell(8);
            cell9.setCellValue("发布日期");
            cell9.setCellStyle(style);
    
            HSSFCell cell10 = row.createCell(9);
            cell10.setCellValue("sku");
            cell10.setCellStyle(style);
    
            HSSFCell cell11 = row.createCell(10);
            cell11.setCellValue("价格");
            cell11.setCellStyle(style);
            
            HSSFCell cell12 = row.createCell(11);
            cell12.setCellValue("商品标题");
            cell12.setCellStyle(style);
            
            HSSFCell cell13 = row.createCell(12);
            cell13.setCellValue("关键字");
            cell13.setCellStyle(style);
            
            int temp = 1;
            //创建内容
            for(int i=0;i<list.size();i++){
                 row = sheet.createRow(i + temp);
                 row.createCell(0).setCellValue(list.get(i).getId());
                 row.createCell(1).setCellValue(list.get(i).getShopName());
                //中间几个格子业务逻辑较多,所以不贴上来了
                 row.createCell(5).setCellValue(list.get(i).getRemark());
                 row.createCell(6).setCellValue(list.get(i).getOrderPrice());
                 row.createCell(7).setCellValue(list.get(i).getCoupon());
                 row.createCell(8).setCellValue(DateUtils.format(list.get(i).getPublishTime(),"yyyy-MM-dd HH:mm:ss"));
                 row.createCell(9).setCellValue(list.get(i).getSku1().getSkuId());
                 row.createCell(10).setCellValue(list.get(i).getSku1().getPrice());
                 row.createCell(11).setCellValue(list.get(i).getSku1().getProductName());
                 row.createCell(12).setCellValue(list.get(i).getSku1().getKeyWord());
                if(list.get(i).getSku2()!=null) {
                    //第一行是表头,第二行开始插数据
                    temp++;
                    row = sheet.createRow(i + temp);
                    row.createCell(0).setCellValue(list.get(i).getId());
                    row.createCell(1).setCellValue(list.get(i).getShopName());
                    row.createCell(5).setCellValue(list.get(i).getRemark());
                    row.createCell(6).setCellValue(list.get(i).getOrderPrice());
                    row.createCell(7).setCellValue(list.get(i).getCoupon());
                    row.createCell(8).setCellValue(DateUtils.format(list.get(i).getPublishTime(),"yyyy-MM-dd HH:mm:ss"));
                    row.createCell(9).setCellValue(list.get(i).getSku2().getSkuId());
                    row.createCell(10).setCellValue(list.get(i).getSku2().getPrice());
                    row.createCell(11).setCellValue(list.get(i).getSku2().getProductName());
                    row.createCell(12).setCellValue(list.get(i).getSku2().getKeyWord());
                    for(int j = 0;j<9;j++) {//合并单元格的逻辑,我这里只是上下合并,所以后两个参数是一样的。
                        sheet.addMergedRegion(new CellRangeAddress(i + temp-1, i + temp, j, j));
                    }
                }
    
            }
            return wb;
        }
    }
    

    这个其实涉及到了一定的业务逻辑的,划重点就是这个方法的使用。
    然后顺便附上全套的实现(以前记录过,不过重复记录加深印象吧):

        public void excelOut( HttpServletResponse response) {
            //假如这里获取了要导出的数据list,怎么获取自定义
            // excel文件名
            String fileName = "订单导出" + DateUtils.format(new Date()) + ".xls";
            // 创建HSSFWorkbook,别问我list哪来的,我哪知道你数据哪来的
            HSSFWorkbook wb = PoiUtil.getHSSFWorkbook(list);
            // 响应到客户端
            try {
                this.setResponseHeader(response, fileName);
                OutputStream os = response.getOutputStream();
                wb.write(os);
                os.flush();
                os.close();
            } catch (Exception e) {
                e.printStackTrace();
            }
        }
        //发送响应流方法
        public void setResponseHeader(HttpServletResponse response, String fileName) {
            try {
                try {
                    fileName = new String(fileName.getBytes(),"ISO8859-1");
                } catch (UnsupportedEncodingException e) {
                    e.printStackTrace();
                }
                response.setContentType("application/octet-stream;charset=ISO8859-1");
                response.setHeader("Content-Disposition", "attachment;filename="+ fileName);
                response.addHeader("Pargam", "no-cache");
                response.addHeader("Cache-Control", "no-cache");
            } catch (Exception ex) {
                ex.printStackTrace();
            }
        }
    

    至此,整个功能over~
    这篇笔记就记到这里,都是重复的知识,因为用到了所以再记录一遍~~反正闲着也是闲着、如果稍微帮到你了记得点个喜欢点个关注。也祝大家工作顺顺利利!另外java技术交流群:130031711,欢迎各位萌新大佬踊跃加入!

    相关文章

      网友评论

        本文标题:java使用poi导出实现单元格合并

        本文链接:https://www.haomeiwen.com/subject/wrzktktx.html