POI入门教程

合集下载
相关主题
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

内部资料不得拷贝

POI报表

--用POI与Excel交互AURISOFT

第一章POI简介

--Jakata Poi HSSF:纯java的Excel解决方案

在我们实际的开发中,表现层的解决方案虽然有多样,但是IE浏览器已成为最多人使

用的浏览器,因为大家都用Windows。在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统、银行系统)。或者是:我们已经习惯用Excel打印。

Apache的Jakata项目的POI子项目,目前比较成熟的是HSSF接口,处理MSExcel对象。它不象我们仅仅是用csv生成的没有格式的可以由Excel转换的东西,而是真正的Excel 对象,你可以控制一些属性如sheet,cell等等。

首先,理解一下一个Excel的文件的组织形式,一个Excel文件对应于一个workbook(HSSFWorkbook),一个workbook可以有多个sheet(HSSFSheet)组成,一个sheet是由多个row(HSSFRow)组成,一个row是由多个cell(HSSFCell)组成。

POI可以到下载到。实际运行时,需要有poi包就可以了。HSSF提供给用户使用的对象在ermodel包中,主要部分包括Excel对象,样式和格式,还有辅助操作。有以下几种对象:

HSSFWorkbook excel的文档对象

HSSFSheet excel的表单

HSSFRow excel的行

HSSFCell excel的格子单元

HSSFFont excel字体

HSSFDataFormat 日期格式

在poi1.7中才有以下2项:

HSSFHeader sheet头

HSSFFooter sheet尾(只有打印的时候才能看到效果)和这个样式

HSSFCellStyle cell样式

辅助操作包括

HSSFDateUtil 日期

HSSFPrintSetup 打印

HSSFErrorConstants 错误信息表

以下可能需要使用到如下的类

import ermodel.HSSFCell;

import ermodel.HSSFCellStyle;

import ermodel.HSSFDataFormat;

import ermodel.HSSFFont;

import ermodel.HSSFRow;

import ermodel.HSSFSheet;

import ermodel.HSSFWorkbook;

import org.apache.poi.hssf.util.HSSFColor;

先看poi的examples包中提供的最简单的例子,建立一个空xls文件。

import java.io.FileOutputStream;

import java.io.IOException;

import ermodel.HSSFWorkbook;

public class ExcelSample1 {

public static void main(String[] args) throws IOException {

//创建一个excel文件

HSSFWorkbook wb= new HSSFWorkbook();

FileOutputStream fileOut= new FileOutputStream("c:\\workbook.xls");

// FileOutputStream fileOut= new FileOutputStream("c:/workbook.xls");

wb.write(fileOut);

fileOut.close();

}

}

通过这个例子,我们在c盘下建立的是一个空白的xls文件(不是空文件)。在此基础上,我们可以进一步看其它的例子。

import ermodel.*;

import java.io.FileOutputStream;

import java.io.IOException;

public class CreateCells

{

public static void main(String[] args) throws IOException

{

HSSFWorkbook wb = new HSSFWorkbook(); //建立新HSSFWorkbook对象

HSSFSheet sheet = wb.createSheet("new sheet"); //建立新的sheet对象

HSSFRow row = sheet.createRow((short)0);

//在sheet里创建一行,参数为行号(第一行,此处可想象成数组)

HSSFCell cell = row.createCell((short)0);

//在row里建立新cell(单元格),参数为列号(第一列)

cell.setCellvalue(1); //设置cell的整数类型的值

row.createCell((short)1).setCellvalue(1.2); //设置cell浮点类型的值

row.createCell((short)2).setCellvalue("test"); //设置cell字符类型的值

row.createCell((short)3).setCellvalue(true); //设置cell布尔类型的值

相关文档
最新文档