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

额,单纯的一个记录贴。因为最近做模板导出这个格式比较多变。所以涉及到了单元格合并。这里简单的记录一下:
首先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~
这篇笔记就记到这里,都是重复的知识,因为用到了所以再记录一遍~~反正闲着也是闲着、如果稍微帮到你了记得点个喜欢点个关注。也祝大家工作顺顺利利!!

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容