POI自定义EXCEL导出

Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。

 

//创建Excel工作簿
        HSSFWorkbook workbook = new HSSFWorkbook();
        //创建Excel表名称
        HSSFSheet sheet = workbook.createSheet("");
        HSSFCell cell = null;
        //设置单元格字体样式
        HSSFCellStyle cellStyle = workbook.createCellStyle();
        HSSFFont font = workbook.createFont();
        //居中
        cellStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER);
        font.setFontHeightInPoints((short)12);
        font.setFontName("黑体");
        cellStyle.setFont(font);

 

上面是创建了EXCEL工作簿,定义了一些基本的单元格样式

//第一行主标题信息
        HSSFRow row0 = sheet.createRow(0);
        //设置行高
        row0.setHeight((short) 500);
        cell = row0.createCell(0);
        cell.setCellValue(new HSSFRichTextString(""));
        cell.setCellStyle(cellStyle);
        int size = departs.size()+4;
        //为每列设置单元格宽度
        for(int i=0;i<size;i++){
            sheet.setColumnWidth(i, 5000);
        }
        CellRangeAddress range = new CellRangeAddress(0, 0, 0,size);   
        sheet.addMergedRegion(range);
        //第二行相关标题
        HSSFRow row1 = sheet.createRow(1);
        row1.setHeight((short) 400);

      初始化第一行,定义行高等样式;创建单元格,给单元格赋值,根据算法定义默认的列宽;进行了单元格合并

      单元格合并API,new CellRangeAddress(int 开始行,int 结束行,int 开始列,int 结束列);

     下面就开始根据需要给每行和对应的每列单元格赋值,并将excel导出

//写excel导出信息
        String fileName = ".xls";
        rep.setHeader("Content-disposition",
                "attachment; filename=" + new String(fileName.getBytes("GB2312"), "ISO8859-1"));
        // 设定输出文件头
        rep.setContentType("application/msexcel");// 定义输出类型
        OutputStream outputStream = rep.getOutputStream();
        workbook.write(outputStream);
        outputStream.flush();
        outputStream.close();

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值