POI中设置Excel单元格格式

Posted ycyk_168

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了POI中设置Excel单元格格式相关的知识,希望对你有一定的参考价值。

引用:http://apps.hi.baidu.com/share/detail/17249059


POI中可能会用到一些需要设置EXCEL单元格格式的操作小结:


先获取工作薄对象:


HSSFWorkbook wb = new HSSFWorkbook();


HSSFSheet sheet = wb.createSheet();


HSSFCellStyle setBorder = wb.createCellStyle();


一、设置背景色:


setBorder.setFillForegroundColor((short) 13);// 设置背景色
setBorder.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);


二、设置边框:


setBorder.setBorderBottom(HSSFCellStyle.BORDER_THIN); //下边框
setBorder.setBorderLeft(HSSFCellStyle.BORDER_THIN);//左边框
setBorder.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框
setBorder.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框


三、设置居中:


setBorder.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 居中


四、设置字体:


HSSFFont font = wb.createFont();
font.setFontName("黑体");
font.setFontHeightInPoints((short) 16);//设置字体大小


HSSFFont font2 = wb.createFont();
font2.setFontName("仿宋_GB2312");
font2.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);//粗体显示
font2.setFontHeightInPoints((short) 12);


setBorder.setFont(font);//选择需要用到的字体格式


五、设置列宽:


sheet.setColumnWidth(0, 3766); //第一个参数代表列id(从0开始),第2个参数代表宽度值  参考 :"2012-08-10"的宽度为2500


六、设置自动换行:


setBorder.setWrapText(true);//设置自动换行


七、合并单元格:


Region region1 = new Region(0, (short) 0, 0, (short) 6);


//参数1:行号 参数2:起始列号 参数3:行号 参数4:终止列号


或者用


CellRangeAddress region1 = new CellRangeAddress(rowNumber, rowNumber, (short) 0, (short) 11);


但应注意两个构造方法的参数不是一样的,具体使用哪个取决于POI的不同版本。
sheet.addMergedRegion(region1);


目前用过的就这么多,后续有新的会继续添加。

以上是关于POI中设置Excel单元格格式的主要内容,如果未能解决你的问题,请参考以下文章

用Java在excel单元格中设置超链接

如何在 iReport 中设置 Excel 单元格格式

请问怎么在excel单元格格式添加自定义

怎么在excel中设置自定义日期格式

为啥我的EXCEL的“设置单元格格式”不行?

JAVA POI 导出 EXCEL模板 怎么设置单元格格式为 文字