一、 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. php自学提升进阶路线

    为了自己对php的系统全面深入的掌握,我通过个人经验,以及搜索网上高手经验,汇总了一份php自我学习路线规划,包括实战演练.学习建议.高手进阶.常见问题和测试总结五块.算是一个系统的学习计划和目标吧. ...

  2. 如何解决Oracle RAC 安装集群软件或数据库时无法自动识别节点

    在节点一 grid用户下: $ORACLE_HOME=/u01/app/11.2.0/grid/ [grid@orarac1 /]$ cd /u01/app/11.2.0/grid/oui/bin [ ...

  3. c#执行bat批处理文件,并通过线程将结果显示在控件中

    核心代码如下: Process p = new Process(); p.StartInfo.FileName = filePath; p.StartInfo.UseShellExecute = fa ...

  4. 【python】python定时器

    #coding:utf-8 import os import time def print_ts(message): print "[%s] %s"%(time.strftime( ...

  5. Laravel项目目录结构说明

    Laravel项目目录结构说明: |- vendor 目录包含你的 Composer 依赖模块及laravel框架. |- bootstrap 目录包含几个框架启动跟自动加载配置的文件. |- app ...

  6. 无索引状态下比较DataTable的几种过滤方法效率

    先构造一个DataTable: public DataTable GetDataTable() { DataTable dtTmp = new DataTable(); dtTmp.Columns.A ...

  7. javascript的一点学习

    最近用vue.js用的很爽,在全栈开发的路上一路狂奔,发现后台跟前台一起确实更有意义. 记录一个比较有意思的bug: 目标是对一个全局的paramList进行json格式化显示.代码借鉴了 http: ...

  8. iOS5.0以上使用新浪微博开放平台OAuth 续(及解决登录无效问题)

    新浪微博开放平台为第三方应用提供了简便的合作模式,满足了手机用户和平板电脑用户随时随地分享信息的需求.通过调用平台的api即可实现很多微博上的功能. 本篇主要目的是记录新浪微博移动SDK iOS版本的 ...

  9. jQuery MiniUI开发系列之:UI和数据分离

    使用MiniUI需要注意:UI和数据是分离的. 传统的WEB开发,开发者经常将数据库操作.服务端业务.HTML标签写在一个页面内. 这样会造成开发的混乱,并且难以维护和升级. 使用MiniUI开发的时 ...

  10. PHP常用函数(1)

    1. create_linkstring 说明: 把数组拼接成字符串 if (!function_exists('create_linkstring')) { /** * 把数组所有元素,按照“参数= ...