一、 POI简介

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

二、 HSSF概况

HSSF 是Horrible SpreadSheet Format的缩写,通过HSSF,你可以用纯Java代码来读取、写入、修改Excel文件。HSSF 为读取操作提供了两类API:usermodel和eventusermodel,即“用户模型”和“事件-用户模型”。

三、 POI EXCEL文档结构类

HSSFWorkbook excel文档对象

HSSFSheet excel的sheet HSSFRow excel的行

HSSFCell excel的单元格 HSSFFont excel字体

HSSFName 名称 HSSFDataFormat 日期格式

HSSFHeader sheet头

HSSFFooter sheet尾

HSSFCellStyle cell样式

HSSFDateUtil 日期

HSSFPrintSetup 打印

HSSFErrorConstants 错误信息表

四、 EXCEL常用操作方法

1、 得到Excel常用对象

  1. POIFSFileSystem fs=newPOIFSFileSystem(new FileInputStream("d:/test.xls"));
  2. //得到Excel工作簿对象
  3. HSSFWorkbook wb = new HSSFWorkbook(fs);
  4. //得到Excel工作表对象
  5. HSSFSheet sheet = wb.getSheetAt(0);
  6. //得到Excel工作表的行
  7. HSSFRow row = sheet.getRow(i);
  8. //得到Excel工作表指定行的单元格
  9. HSSFCell cell = row.getCell((short) j);
  10. cellStyle = cell.getCellStyle();//得到单元格样式

2、建立Excel常用对象

  1. HSSFWorkbook wb = new HSSFWorkbook();//创建Excel工作簿对象
  2. HSSFSheet sheet = wb.createSheet("new sheet");//创建Excel工作表对象
  3. HSSFRow row = sheet.createRow((short)0); //创建Excel工作表的行
  4. cellStyle = wb.createCellStyle();//创建单元格样式
  5. row.createCell((short)0).setCellStyle(cellStyle); //创建Excel工作表指定行的单元格
  6. row.createCell((short)0).setCellValue(1); //设置Excel工作表的值
3、设置sheet名称和单元格内容
  1. wb.setSheetName(1, "第一张工作表",HSSFCell.ENCODING_UTF_16);
  2. cell.setEncoding((short) 1);
  3. cell.setCellValue("单元格内容");
4、取得sheet的数目
  1. wb.getNumberOfSheets()
5、  index取得sheet对象
  1. HSSFSheet sheet = wb.getSheetAt(0);
6、取得有效的行数
  1. int rowcount = sheet.getLastRowNum();
7、取得一行的有效单元格个数
  1. row.getLastCellNum();

8、单元格值类型读写

  1. cell.setCellType(HSSFCell.CELL_TYPE_STRING); //设置单元格为STRING类型
  2. cell.getNumericCellValue();//读取为数值类型的单元格内容

9、设置列宽、行高

  1. sheet.setColumnWidth((short)column,(short)width);
  2. row.setHeight((short)height);

10、添加区域,合并单元格

  1. Region region = new Region((short)rowFrom,(short)columnFrom,(short)rowTo
  2. ,(short)columnTo);//合并从第rowFrom行columnFrom列
  3. sheet.addMergedRegion(region);// 到rowTo行columnTo的区域
  4. //得到所有区域
  5. sheet.getNumMergedRegions()

11、保存Excel文件

  1. FileOutputStream fileOut = new FileOutputStream(path);
  2. wb.write(fileOut);

12、根据单元格不同属性返回字符串数值

  1. public String getCellStringValue(HSSFCell cell) {
  2. String cellValue = "";
  3. switch (cell.getCellType()) {
  4. case HSSFCell.CELL_TYPE_STRING://字符串类型
  5. cellValue = cell.getStringCellValue();
  6. if(cellValue.trim().equals("")||cellValue.trim().length()<=0)
  7. cellValue=" ";
  8. break;
  9. case HSSFCell.CELL_TYPE_NUMERIC: //数值类型
  10. cellValue = String.valueOf(cell.getNumericCellValue());
  11. break;
  12. case HSSFCell.CELL_TYPE_FORMULA: //公式
  13. cell.setCellType(HSSFCell.CELL_TYPE_NUMERIC);
  14. cellValue = String.valueOf(cell.getNumericCellValue());
  15. break;
  16. case HSSFCell.CELL_TYPE_BLANK:
  17. cellValue=" ";
  18. break;
  19. case HSSFCell.CELL_TYPE_BOOLEAN:
  20. break;
  21. case HSSFCell.CELL_TYPE_ERROR:
  22. break;
  23. default:
  24. break;
  25. }
  26. return cellValue;
  27. }

13、常用单元格边框格式

  1. HSSFCellStyle style = wb.createCellStyle();
  2. style.setBorderBottom(HSSFCellStyle.BORDER_DOTTED);//下边框
  3. style.setBorderLeft(HSSFCellStyle.BORDER_DOTTED);//左边框
  4. style.setBorderRight(HSSFCellStyle.BORDER_THIN);//右边框
  5. style.setBorderTop(HSSFCellStyle.BORDER_THIN);//上边框

14、设置字体和内容位置

  1. HSSFFont f  = wb.createFont();
  2. f.setFontHeightInPoints((short) 11);//字号
  3. f.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);//加粗
  4. style.setFont(f);
  5. style.setAlignment(HSSFCellStyle.ALIGN_CENTER);//左右居中
  6. style.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);//上下居中
  7. style.setRotation(short rotation);//单元格内容的旋转的角度
  8. HSSFDataFormat df = wb.createDataFormat();
  9. style1.setDataFormat(df.getFormat("0.00%"));//设置单元格数据格式
  10. cell.setCellFormula(string);//给单元格设公式
  11. style.setRotation(short rotation);//单元格内容的旋转的角度

15、插入图片

  1. //先把读进来的图片放到一个ByteArrayOutputStream中,以便产生ByteArray
  2. ByteArrayOutputStream byteArrayOut = new ByteArrayOutputStream();
  3. BufferedImage bufferImg = ImageIO.read(new File("ok.jpg"));
  4. ImageIO.write(bufferImg,"jpg",byteArrayOut);
  5. //读进一个excel模版
  6. FileInputStream fos = new FileInputStream(filePathName+"/stencil.xlt");
  7. fs = new POIFSFileSystem(fos);
  8. //创建一个工作薄
  9. HSSFWorkbook wb = new HSSFWorkbook(fs);
  10. HSSFSheet sheet = wb.getSheetAt(0);
  11. HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
  12. HSSFClientAnchor anchor = new HSSFClientAnchor(0,0,1023,255,(short) 0,0,(short)10,10);
  13. patriarch.createPicture(anchor , wb.addPicture(byteArrayOut.toByteArray(),HSSFWorkbook.PICTURE_TYPE_JPEG));

16、调整工作表位置

  1. HSSFWorkbook wb = new HSSFWorkbook();
  2. HSSFSheet sheet = wb.createSheet("format sheet");
  3. HSSFPrintSetup ps = sheet.getPrintSetup();
  4. sheet.setAutobreaks(true);
  5. ps.setFitHeight((short)1);
  6. ps.setFitWidth((short)1);

17、设置打印区域

  1. HSSFSheet sheet = wb.createSheet("Sheet1");
  2. wb.setPrintArea(0, "$A$1:$C$2");

18、标注脚注

  1. HSSFSheet sheet = wb.createSheet("format sheet");
  2. HSSFFooter footer = sheet.getFooter()
  3. footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() );

19、在工作单中清空行数据,调整行位置

  1. HSSFWorkbook wb = new HSSFWorkbook();
  2. HSSFSheet sheet = wb.createSheet("row sheet");
  3. // Create various cells and rows for spreadsheet.
  4. // Shift rows 6 - 11 on the spreadsheet to the top (rows 0 - 5)
  5. sheet.shiftRows(5, 10, -5);

20、选中指定的工作表

  1. HSSFSheet sheet = wb.createSheet("row sheet");
  2. heet.setSelected(true);

21、工作表的放大缩小

  1. HSSFSheet sheet1 = wb.createSheet("new sheet");
  2. sheet1.setZoom(1,2);   // 50 percent magnification

22、头注和脚注

  1. HSSFSheet sheet = wb.createSheet("new sheet");
  2. HSSFHeader header = sheet.getHeader();
  3. header.setCenter("Center Header");
  4. header.setLeft("Left Header");
  5. header.setRight(HSSFHeader.font("Stencil-Normal", "Italic") +
  6. HSSFHeader.fontSize((short) 16) + "Right w/ Stencil-Normal Italic font and size 16");

23、自定义颜色

  1. HSSFCellStyle style = wb.createCellStyle();
  2. style.setFillForegroundColor(HSSFColor.LIME.index);
  3. style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
  4. HSSFFont font = wb.createFont();
  5. font.setColor(HSSFColor.RED.index);
  6. style.setFont(font);
  7. cell.setCellStyle(style);

24、填充和颜色设置

  1. HSSFCellStyle style = wb.createCellStyle();
  2. style.setFillBackgroundColor(HSSFColor.AQUA.index);
  3. style.setFillPattern(HSSFCellStyle.BIG_SPOTS);
  4. HSSFCell cell = row.createCell((short) 1);
  5. cell.setCellValue("X");
  6. style = wb.createCellStyle();
  7. style.setFillForegroundColor(HSSFColor.ORANGE.index);
  8. style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
  9. cell.setCellStyle(style);

25、强行刷新单元格公式

  1. HSSFFormulaEvaluator eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);
  2. private static void updateFormula(Workbook wb,Sheet s,int row){
  3. Row r=s.getRow(row);
  4. Cell c=null;
  5. FormulaEcaluator eval=null;
  6. if(wb instanceof HSSFWorkbook)
  7. eval=new HSSFFormulaEvaluator((HSSFWorkbook) wb);
  8. else if(wb instanceof XSSFWorkbook)
  9. eval=new XSSFFormulaEvaluator((XSSFWorkbook) wb);
  10. for(int i=r.getFirstCellNum();i
  11. c=r.getCell(i);
  12. if(c.getCellType()==Cell.CELL_TYPE_FORMULA)
  13. eval.evaluateFormulaCell(c);
  14. }
  15. }

说明:FormulaEvaluator提供了evaluateFormulaCell(Cell cell)方法,计算公式保存结果,但不改变公式。而evaluateInCell(Cell cell) 方法是计算公式,并将原公式替换为计算结果,也就是说该单元格的类型不在是Cell.CELL_TYPE_FORMULA而是Cell.CELL_TYPE_NUMBERIC。HSSFFormulaEvaluator提供了静态方法evaluateAllFormu

laCells(HSSFWorkbook wb) ,计算一个Excel文件的所有公式,用起来很方便。

------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------poi方法总结

-.设置不显示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);//自动根据长度调整单元格长度

poi API的更多相关文章

  1. [Training Video - 6] [File Reading] [Java] Read Excel File Using Apache POI API

    读取以下两种格式的Excel : *.xls  and *.xlsx 用Apache POI API来实现,需要用到 HSSF 和 XSSF 的类库 HSSF is the POI Project's ...

  2. poi api工具

    ------------官网api地址 http://poi.apache.org/apidocs/index.html ------------官方下载地址 http://poi.apache.or ...

  3. Excel poi API基础教程!

    原文转子: http://blog.csdn.net/yellowd1/article/details/44628701 登录|注册     yellowd1的专栏       目录视图 摘要视图 订 ...

  4. poi API大全

    一. POI简介 Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能. 二. HSSF概况 HSSF 是 ...

  5. [Training Video - 6] [File Reading] [Java] Create and Write Excel File Using Apache POI API

    package com.file.properties; import java.io.File; import java.io.FileNotFoundException; import java. ...

  6. JAVA的POI操作Excel

    1.1Excel简介 一个excel文件就是一个工作簿workbook,一个工作簿中可以创建多张工作表sheet,而一个工作表中包含多个单元格Cell,这些单元格都是由列(Column)行(Row)组 ...

  7. 在线api地址

    J2SE1.7英文api地址: http://download.oracle.com/javase/7/docs/api/J2SE1.6英文api地址:  http://download.oracle ...

  8. apache poi导出excel报表

    Apache POI 是用Java编写的免费开源的跨平台的 Java API,Apache POI提供API给Java程式对Microsoft Office格式档案读和写的功能.POI为"P ...

  9. java操作excel总结---poi

    前不久做过Excel的导入导出功能,其主要的难点是java如何操作Excel文档.现在就来介绍一下利用Apache的poi如何操作Excel. 1.准备工作:导入Apache POI的相关jar包,P ...

随机推荐

  1. 【性能诊断】StackOverflow引发的“网络”及系统稳定性问题

    背景描述: 最近一个项目的系统管理员和业务运维人员分别反馈问题: 1.应用系统每个月会有一两次宕机,需要管理员手工重启IIS: 2.财务模块一个功能经常报网络错误“网络异常,请检查网络连接”“Unab ...

  2. oracle11g重置system密码,外二

    来自:http://lukeview.blog.51cto.com/508652/912124 win+r,输入sqlplus /nolog,回车SQL> conn /as sysdba已连接: ...

  3. Linux uniq常用命令

    -u 只显示不重复行.-d 只显示有重复数据行,每种重复行只显示其中一行-c 打印每一重复行出现次数.-f n为数字,前n个域被忽略.一些系统不识别- f选项,这时替代使用- n.

  4. cWeb开发框架,基于asp.net的cWeb应用开发平台介绍(二)

    cWeb是基于微软的.Net Framework 4框架,数据库是sql server 2008 r2. cWeb开发框架下载,点击这里去下载. cWeb开发框架借鉴三层架构理论分为三层,分别是:cD ...

  5. 怎么查看bios版本

    怎么查看bios版本呢?无需去注册表查看,无需去BIOS中查看,只需要一条简单的命令即可,下面就来一起看一看怎么查看bios版本: Win键+R打开“运行”,然后再“运行”中输入cmd进而打开“cmd ...

  6. Fastboot模式和Recovery模式

    http://blog.csdn.net/luoshengyang/article/details/29688041 在回答第一个问题之前,我们先来看看Android设备从硬件到系统的结构,如图1所示 ...

  7. MySQL三大数据类型

  8. 黄聪:微信支付错误两个问题的解决:curl出错,错误码:60

    如下是运行微信支付测试代码时出错代码: Warning: curl_setopt() expects parameter 2 to be long, string given in D:\wwwroo ...

  9. Spark 1.6以后的内存管理机制

     Spark 内部管理机制 Spark的内存管理自从1.6开始改变.老的内存管理实现自自staticMemoryManager类,然而现在它被称之为"legacy". " ...

  10. jQuery MiniUI开发系列之:创建组件对象

    jQuery MiniUI可以使用Javascript和Html两种方式来创建对象. 1)Javascript创建对象 使用JavaScript创建对象,是最基本的方式,有如下几个要点: 1)使用ne ...