我使用的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)