poi操作
创建一个excel关联对象HSSFWorkbook:
HSSFWorkbook book = new HSSFWorkbook();
创建一个sheet:
HSSFSheet st = book.createSheet("sheet1");
创建第i行:
HSSFRow row = st.createRow(i);
创建第i行的j列:
HSSFCell cell = row.createCell(j);
设置cell属性
给单元格设置边框属性:
HSSFCellStyle style = book.createCellStyle(); // 左右上下边框样式 style.setBorderLeft(HSSFCellStyle.BORDER_THIN); style.setBorderRight(HSSFCellStyle.BORDER_THIN); style.setBorderTop(HSSFCellStyle.BORDER_THIN); style.setBorderBottom(HSSFCellStyle.BORDER_THIN); // 左右上下边框颜色(深蓝色),只有设置了上下左右边框以后给边框设置颜色才会生效 style.setLeftBorderColor(HSSFColor.BLACK.index); style.setRightBorderColor(HSSFColor.BLACK.index); style.setTopBorderColor(HSSFColor.BLACK.index); style.setBottomBorderColor(HSSFColor.BLACK.index);
给单元格设置背景:
style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);// 设置了背景色才有效果 style.setFillForegroundColor(HSSFColor.GREY_25_PERCENT.index);
给单元格设置字体:
// 单元格字体 HSSFFont font = book.createFont(); font.setFontName("宋体");
设置字体以后,需要把字体加入到style中:
设置好单元格属性以后,需要这种属性的单元格就可以调用此style:
cell.setCellStyle(style);
设置sheet表单的列宽:
st.setColumnWidth(i, cellWidths.get(i).intValue() * 160);
列宽的设置方法在HSSFSheet中,方法参数:第一个参数表示第几列,从0开始数;第二个参数表示宽度为多少,大小由使用者调整。
合并单元格:
st.addMergedRegion(new CellRangeAddress(0, 1, 0, keys.size() - 1));
单元格合并方法也是在HSSFSheet中,方法参数:一个CellRangeAddress,该类构造函数的4个参数分别表示为:合并开始行,合并结束行,合并开始列,合并结束列
注:
合并方法最好写在最后面,不然有可能会影响到某些单元格添加单元格属性的操作
下面是我写的一个根据传入的数据,把数据导出到excel的接口:
/** * 导出到excel 导出的路径以及导出文件名称在配置文件中定义 * 在任何地方此方法可以作为组件调用的,只需要提供需要保存的数据,每一列的属性,以及对应的中文名称,每一列的宽度,文件路径,文件名称 * * @param list * the data which will be saved to excel * @param keys * the key of the column * @param cnames * the name described in Chinese * @param cellWidths * the width of olumns * @param excelPath * the path of excel * @param fileName * the name of the file in server */ public HSSFWorkbook doExportResults(List