`
xiongzhenhui
  • 浏览: 205634 次
  • 性别: Icon_minigender_1
  • 来自: 厦门
社区版块
存档分类
最新评论

poi生成excel开发难点总结

    博客分类:
  • poi
阅读更多
1.设置不显示excel网格线
  sheet.setDisplayGridlines(false);其中sheet是Sheet对象
2.设置excel单元格中的内容换行
  cellStyle.setWrapText(true);其中cellStyle是WorkBook创建的CellStyle对象,然后将cellStyle设置到要换行的Cell对象,最后在要换行的对象(一般为字符串)加入"\r\n"。如
topTile.append("\r\n" +"cellContent");

3.单元格的合并
  sheet.addMergedRegion(new CellRangeAddress(0, 4, 0, 2));本示例为合并4行2列

4.设置页眉和页脚的页数
    HSSFHeader header = sheet.getHeader();
    header.setCenter("Center Header");
    header.setLeft("Left Header");
    header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") +
    HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");

  HSSFFooter footer = (HSSFFooter )sheet.getFooter()
  footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() );

5.使得一个Sheet适合一页
  sheet.setAutobreaks(true);
6.设置放大属性(Zoom被明确为一个分数,例如下面的75%使用3作为分子,4作为分母)
  sheet.setZoom(3,4);  

7.设置打印
  HSSFPrintSetup print = (HSSFPrintSetup) sheet.getPrintSetup();
  print.setLandscape(true);//设置横向打印
  print.setScale((short) 70);//设置打印缩放70%
  print.setPaperSize(HSSFPrintSetup.A4_PAPERSIZE);//设置为A4纸张
  print.setLeftToRight(true);//設置打印顺序先行后列,默认为先列行           
  print.setFitHeight((short) 10);设置缩放调整为10页高
  print.setFitWidth((short) 10);设置缩放调整为宽高

  sheet.setAutobreaks(false);
  if (i != 0 && i % 30 == 0)
      sheet.setRowBreak(i);//設置每30行分頁打印

8.反复的行和列(设置打印标题)
  HSSFWorkbook wb = new HSSFWorkbook();
  wb.setRepeatingRowsAndColumns(0, 0, 12, 1, 6);//设置1到12列,行1到6每一页重复打印

9.调整单元格宽度
  sheet.setAutobreaks(true);
  sheet.setColumnWidth((short)i,colsWidth[i]); //设定单元格长度
    sheet.autoSizeColumn((short) i);//自动根据长度调整单元格长度

10.获取excel2003总打印页数
   sheet.getRowBreaks().length + 1





 
0
0
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics