使用Apache poi导出Excel总结

本文演示了如何使用ApachePOI4.1.2版本生成Excel文件,包括创建Workbook,设置边框,创建Sheet,调整行高、列宽,设置单元格样式,合并单元格以及处理网页下载。代码示例详细展示了整个过程。
摘要由CSDN通过智能技术生成

我使用的poi版本是4.1.2。

下面开始我们的使用之旅。

首先就是我们生成excel的方法

  /**
     * 使用try with source方式即 try(){}catch
     * 我们可以将需要关闭的资源写在try后面的括号中,会自动关闭需要关闭的资源,避免资源得不到关闭
     * @param args
     */
    public static void main(String[] args) {
        try(
            //生成导出xlsx文件的类;用于创建工作簿;它提供了创建,读取和写入excel的方法
            Workbook wb = new HSSFWorkbook();
            //文件输出流,指定输出文件的位置,输出到d盘下的test文件夹中a.xlsx文件中
            FileOutputStream fos = new FileOutputStream("d:\\test\\a.xlsx"))
        {
            //生成绘制边框的对象,PropertyTemplate对象允许绘图的顶部,底部常量,左,右,水平,垂直,里面,单元格外边界
            PropertyTemplate pt = new PropertyTemplate();
            //绘制一个6 × 6 的表格边框,excel的第一行第一列都是从0开始的,一定不要弄错了
            //绘制从第一行到第六行的表格,BorderStyle.THIN的意思是填充细线,BorderExtent.ALL的意思是内部全部填充
            pt.drawBorders(new CellRangeAddress(0, 5, 0, 5),
                    BorderStyle.THIN, BorderExtent.ALL);
            //生成一个sheet页,sheet页的名称叫做测试sheet1
            Sheet sheet = wb.createSheet("测试sheet1");

            //将绘制的边框应用到哪一个sheet中去
            pt.applyBorders(sheet);
            //将缓冲区的内容刷进去,如果少了这一步,excel是没有内容的
            fos.flush();
            //将输出流的内容写入进excel
            wb.write(fos);
        }catch (Exception e){
            e.printStackTrace();
        }
    }

顺便提一下,如果想生成的excel在网页上导出下载,那我们需要配置一些东西

具体如下:

 public static OutputStream getOutputStream(HttpServletResponse response, String fileName) throws IOException {
        response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");
        response.setHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode(fileName,"UTF-8"));
        //  客户端不缓存
        response.addHeader("Pragma", "no-cache");
        response.addHeader("Cache-Control", "no-cache");
        return response.getOutputStream();
    }

下面我们准备运行main方法,来看一下效果如何

执行main方法前,此时我d盘test文件夹中是没有文件的

执行main方法后,我文件夹中多出了a.xlsx文件,说明我们方法是正确的

我们来看看a.xlsx文件里面内容

 下面我们就要开始正式使用poi操作excel了

            //创建单元格样式
            CellStyle cellStyle = wb.createCellStyle();
            //创建字体样式
            Font font = wb.createFont();
            //设置字体高度大小
            font.setFontHeightInPoints((short) 11);
            //设置字体
            font.setFontName("宋体");
            cellStyle.setFont(font);
            //设置垂直对齐居中
            cellStyle.setVerticalAlignment(VerticalAlignment.CENTER);
            //设置水平对齐居中
            cellStyle.setAlignment(HorizontalAlignment.CENTER);
            //设置自动换行
            cellStyle.setWrapText(true);

            //创建第一列对象,并设置高度为600
            Row row1 = sheet.createRow(0);
            row1.setHeight((short) 600);
            Row row2 = sheet.createRow(1);
            row2.setHeight((short) 500);
            Row row3 = sheet.createRow(2);
            row3.setHeight((short) 400);
            Row row4 = sheet.createRow(3);
            row4.setHeight((short) 300);
            Row row5 = sheet.createRow(4);
            row5.setHeight((short) 200);
            Row row6 = sheet.createRow(5);
            row6.setHeight((short) 100);

            //第一列第一行对象
            Cell cell1 = row1.createCell(0);
            //设置单元格格式
            cell1.setCellStyle(cellStyle);
            //设置单元格内容
            cell1.setCellValue("啦啦啦啦啦啦啦");
             //设置列宽度为1000
            sheet.setColumnWidth(0, 1000);

            //第一列第二行对象
            Cell cell2 = row1.createCell(1);
            cell2.setCellStyle(cellStyle);
            cell2.setCellValue("两只老虎 两只老虎 跑得快 跑得快 一只没有眼睛 一只没有耳朵 真奇怪 真奇怪");
            //合并单元格,合并第一行的2-6列
            sheet.addMergedRegion(new CellRangeAddress(0,0,1,5));

下面看看结果如何

我们能发现,字体以及字体高度大小都是我们设置的指定值;并且列的宽度,行的高度也是我们指定之后的大小;而且文字进行自动换行了,十分符合我们的预期。

继续对excel进行操作

            //第二行第一列对象
            cell1 =  row2.createCell(0);
            cell1.setCellStyle(cellStyle);
            cell1.setCellValue("今天天气很好,我们出去玩吧!");
            //合并单元格,合并第二行到第四行,第一列到第二列
            sheet.addMergedRegion(new CellRangeAddress(1,3,0,1));

            //第二行第三列对象
            Cell cell3 = row2.createCell(2);
            cell3.setCellStyle(cellStyle);
            cell3.setCellValue("我是大合并单元格");
            //合并第二行到第六行,第三列到第六列
            sheet.addMergedRegion(new CellRangeAddress(1,5,2,5));

            //第五行第一列对象
            Cell cell4 = row5.createCell(0);
            cell4.setCellStyle(cellStyle);
            cell4.setCellValue("我是小合并单元格");
            sheet.addMergedRegion(new CellRangeAddress(4,5,0,1));

            //这样是会没数据的,因为row6已经合并了
            Cell cell5 = row6.createCell(0);
            cell5.setCellStyle(cellStyle);
            cell5.setCellValue("表格最后的数据");

            //绘制一个从第十行到第十六行的表格,填充标准线,只填充外边缘
            pt.drawBorders(new CellRangeAddress(9,14,9,14),
                    BorderStyle.MEDIUM,BorderExtent.OUTSIDE);
            sheet.addMergedRegion(new CellRangeAddress(9,14,9,14));

我们仔细观察cell5的数据,在excel中是没有出现的

 更多poi操作excel的方式可以参考:Apache POI教程 - 一点教程 (yiidian.com)

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值