文档库 最新最全的文档下载
当前位置:文档库 › poi教程

poi教程

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可以到https://www.wendangku.net/doc/3f15170757.html,下载到。实际运行时,需要有poi包就可以了。HSSF提供给用户使用的对象在https://www.wendangku.net/doc/3f15170757.html,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 https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFCell;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFCellStyle;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFDataFormat;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFFont;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFRow;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFSheet;

import https://www.wendangku.net/doc/3f15170757.html,ermodel.HSSFWorkbook;

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

通过这个例子,我们在c盘下建立的是一个空白的xls文件(不是空文件)。在此基础

HSSFSheet HSSFRow HSSFCell这样几个对象。我们可以在cell中设置各种类型的值。

尤其要注意的是如果你想正确的显示非欧美的字符时,尤其象中日韩这样的语言,必须设置编码为16位的即是HSSFCell.ENCODING_UTF_16,才能保证字符的高8位不被截断而引起编码失真形成乱码。

其他测试可以通过参考examples包中的测试例子掌握poi的详细用法,包括字体的设置,cell大小和低纹的设置等。需要注意的是POI是一个仍然在完善中的公开代码的项目,所以有些功能正在不断的扩充。

感觉上面的操作比较的繁琐,然后就自己写了一个方法。这个方法不需要事先创建row

对里面的几个参数的说明:

short col 应该是你的cell单元格的位置也就是列号;

short align 应该是你的对齐方式;

String val 应该是你单元格里面要添加的值;

具体的调用如下:

在上边的例子里我们看到了要设置一个单元格里面信息的格式(例如,要将信息居中)设置的操作如下:

这里面我们还要介绍一个经常会遇到的问题,就是怎么来冻结一个窗口。poi也为我们集成了这样的事情了。代码如下:

一、该方法是在一个具体的sheet里面来进行操作。

二、方法createFreezepane;有2个参数。前一个参数代表列;后一个参数代表行。

上边的代码对应的excel文件如下:

我么在画面上看到了明显的两条黑线,这就是冻结的窗口。

然后我们来看一个完整的小例子,在这个例子里面我们要做的事情是要把数据库里面的一张表,把他里面的数据导出到一个具体的Excel文件当中。首先,我们来做一个数据库连接的bean。

然后就是我们具体的FixationExcel这个类了,这里面写的

相关文档
相关文档 最新文档