您好,欢迎访问三七文档
当前位置:首页 > 办公文档 > 其它办公文档 > java_POI教程
JAVA软件工程师教育系列教程1POI报表第一章POI简介--JakataPoiHSSF:纯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提供给用户使用的对象在rg.apache.poi.hssf.usermodel包中,主要部分包括Excel对象,样式和格式,还有辅助操作。有以下几种对象:HSSFWorkbookexcel的文档对象HSSFSheetexcel的表单HSSFRowexcel的行HSSFCellexcel的格子单元HSSFFontexcel字体HSSFDataFormat日期格式在poi1.7中才有以下2项:HSSFHeadersheet头HSSFFootersheet尾(只有打印的时候才能看到效果)和这个样式HSSFCellStylecell样式辅助操作包括HSSFDateUtil日期HSSFPrintSetup打印HSSFErrorConstants错误信息表以下可能需要使用到如下的类importorg.apache.poi.hssf.usermodel.HSSFCell;importorg.apache.poi.hssf.usermodel.HSSFCellStyle;importorg.apache.poi.hssf.usermodel.HSSFDataFormat;importorg.apache.poi.hssf.usermodel.HSSFFont;importorg.apache.poi.hssf.usermodel.HSSFRow;importorg.apache.poi.hssf.usermodel.HSSFSheet;JAVA软件工程师教育系列教程2importorg.apache.poi.hssf.usermodel.HSSFWorkbook;importorg.apache.poi.hssf.util.HSSFColor;先看poi的examples包中提供的最简单的例子,建立一个空xls文件。importjava.io.FileOutputStream;importjava.io.IOException;importorg.apache.poi.hssf.usermodel.HSSFWorkbook;publicclassExcelSample1{publicstaticvoidmain(String[]args)throwsIOException{//创建一个excel文件HSSFWorkbookwb=newHSSFWorkbook();FileOutputStreamfileOut=newFileOutputStream(c:\\workbook.xls);//FileOutputStreamfileOut=newFileOutputStream(c:/workbook.xls);wb.write(fileOut);fileOut.close();}}通过这个例子,我们在c盘下建立的是一个空白的xls文件(不是空文件)。在此基础上,我们可以进一步看其它的例子。importorg.apache.poi.hssf.usermodel.*;importjava.io.FileOutputStream;importjava.io.IOException;publicclassCreateCells{publicstaticvoidmain(String[]args)throwsIOException{HSSFWorkbookwb=newHSSFWorkbook();//建立新HSSFWorkbook对象HSSFSheetsheet=wb.createSheet(newsheet);//建立新的sheet对象HSSFRowrow=sheet.createRow((short)0);//在sheet里创建一行,参数为行号(第一行,此处可想象成数组)HSSFCellcell=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布尔类型的值HSSFCellStylecellStyle=wb.createCellStyle();//建立新的cell样式cellStyle.setDataFormat(HSSFDataFormat.getBuiltinFormat(m/d/yyh:mm));//设置cell样式为定制的日期格式HSSFCelldCell=row.createCell((short)4);dCell.setCellvalue(newDate());//设置cell为日期类型的值dCell.setCellStyle(cellStyle);//设置该cell日期的显示格式HSSFCellcsCell=row.createCell((short)5);JAVA软件工程师教育系列教程3csCell.setEncoding(HSSFCell.ENCODING_UTF_16);//设置cell编码解决中文高位字节截断csCell.setCellvalue(中文测试_ChineseWordsTest);//设置中西文结合字符串row.createCell((short)6).setCellType(HSSFCell.CELL_TYPE_ERROR);//建立错误cellFileOutputStreamfileOut=newFileOutputStream(workbook.xls);wb.write(fileOut);fileOut.close();}}通过这个例子,我们可以清楚的看到xls文件从大到小包括了HSSFWorkbookHSSFSheetHSSFRowHSSFCell这样几个对象。我们可以在cell中设置各种类型的值。尤其要注意的是如果你想正确的显示非欧美的字符时,尤其象中日韩这样的语言,必须设置编码为16位的即是HSSFCell.ENCODING_UTF_16,才能保证字符的高8位不被截断而引起编码失真形成乱码。其他测试可以通过参考examples包中的测试例子掌握poi的详细用法,包括字体的设置,cell大小和低纹的设置等。需要注意的是POI是一个仍然在完善中的公开代码的项目,所以有些功能正在不断的扩充。感觉上面的操作比较的繁琐,然后就自己写了一个方法。这个方法不需要事先创建row和cell,直接进行cteateCell就可以了,在程序中会自动进行判断,如果不存在的话会创建。privatestaticvoidcteateCell(HSSFWorkbookwb,HSSFRowrow,shortcol,shortalign,Stringval){HSSFCellcell=row.createCell(col);cell.setEncoding(HSSFCell.ENCODING_UTF_16);cell.setCellValue(val);HSSFCellStylecellstyle=wb.createCellStyle();cellstyle.setAlignment(align);cell.setCellStyle(cellstyle);}对里面的几个参数的说明:shortcol应该是你的cell单元格的位置也就是列号;shortalign应该是你的对齐方式;Stringval应该是你单元格里面要添加的值;具体的调用如下:HSSFRowrow=sheet.createRow((short)1);cteateCell(wb,row,(short)0,HSSFCellStyle.ALIGN_CENTER_SELECTION,SampleID);在上边的例子里我们看到了要设置一个单元格里面信息的格式(例如,要将信息居中)设置的操作如下:HSSFCellStylecellstyle=wb.createCellStyle();cellstyle.setAlignment(HSSFCellStyle.ALIGN_CENTER_SELECTION);cell.setCellStyle(cellstyle);还有我们我们经常会用到的合并单元格,在这里我们也有这样的操作,代码如下:sheet.addMergedRegion(newRegion(1,(short)1,2,(short)4));JAVA软件工程师教育系列教程4这里面我们还要介绍一个经常会遇到的问题,就是怎么来冻结一个窗口。poi也为我们集成了这样的事情了。代码如下:sheet.createFreezePane(1,2);λ在这里我们需要注意的是一、该方法是在一个具体的sheet里面来进行操作。二、方法createFreezepane;有2个参数。前一个参数代表列;后一个参数代表行。上边的代码对应的excel文件如下:我么在画面上看到了明显的两条黑线,这就是冻结的窗口。然后我们来看一个完整的STRUTS的小例子,在这个例子里面我们要做的事情是要模拟移动公司的网上营业厅里面的一个功能,我们要把一个客户当月的通话记录和各种信息查询出来,并且生成一张excel报表。首先,我们来看一下网上效果的截图。JAVA软件工程师教育系列教程5然后就是我们具体的代码实现了。struts-config.xml?xmlversion=1.0encoding=UTF-8?!DOCTYPEstruts-configPUBLIC-//ApacheSoftwareFoundation//DTDStrutsConfiguration1.2//EN=/searchtype=action.SearchActionforwardname=successpath=/detial.jsp//actionactionpath=/downtype=action.DownActionforwardname=displaypath=/down.jsp//action/action-mappingsmessage-resourcesparameter=ApplicationResources//struts-configindex.jsp%@pagecontentType=text/html;charset=gb2312language=java%J
本文标题:java_POI教程
链接地址:https://www.777doc.com/doc-4007107 .html