`

使用poi一步一步建立报表 (excel操作)

    博客分类:
  • java
阅读更多

 

 

一步一步使用POI做java报表
2008-9-25 15:03:10  作者:模板天下收集整理  来源:未知 网友评论 0 条 论坛1383
  

读取和重写 Workbooks 

POIFSFileSystem fs = 

new POIFSFileSystem(new FileInputStream("workbook.xls")); 

HSSFWorkbook wb = new HSSFWorkbook(fs); 

HSSFSheet sheet = wb.getSheetAt(0); 

HSSFRow row = sheet.getRow(2); 

HSSFCell cell = row.getCell((short)3); 

if (cell == null) 

cell = row.createCell((short)3); 

cell.setCellType(HSSFCell.CELL_TYPE_STRING); 

cell.setCellValue("a test"); 



// 写入文件 

FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



在单元格中换行 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet s = wb.createSheet(); 

HSSFRow r = null; 

HSSFCell c = null; 

HSSFCellStyle cs = wb.createCellStyle(); 

HSSFFont f = wb.createFont(); 

HSSFFont f2 = wb.createFont(); 



cs = wb.createCellStyle(); 



cs.setFont( f2 ); 

//开启Word Wrap 

cs.setWrapText( true ); 



r = s.createRow( (short) 2 ); 

r.setHeight( (short) 0x349 ); 

c = r.createCell( (short) 2 ); 

c.setCellType( HSSFCell.CELL_TYPE_STRING ); 

c.setCellValue( "Use \n with word wrap on to create a new line" ); 

c.setCellStyle( cs ); 

s.setColumnWidth( (short) 2, (short) ( ( 50 * 8 ) / ( (double) 1 / 20 ) ) ); 



FileOutputStream fileOut = new FileOutputStream( "workbook.xls" ); 

wb.write( fileOut ); 

fileOut.close(); 

数据格式化 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("format sheet"); 

HSSFCellStyle style; 

HSSFDataFormat format = wb.createDataFormat(); 

HSSFRow row; 

HSSFCell cell; 

short rowNum = 0; 

short colNum = 0; 



row = sheet.createRow(rowNum++); 

cell = row.createCell(colNum); 

cell.setCellValue(11111.25); 

style = wb.createCellStyle(); 

style.setDataFormat(format.getFormat("0.0")); 

cell.setCellStyle(style); 



row = sheet.createRow(rowNum++); 

cell = row.createCell(colNum); 

cell.setCellValue(11111.25); 

style = wb.createCellStyle(); 

style.setDataFormat(format.getFormat("#,##0.0000")); 

cell.setCellStyle(style); 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



使得一个Sheet适合一页 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("format sheet"); 

HSSFPrintSetup ps = sheet.getPrintSetup(); 



sheet.setAutobreaks(true); 



ps.setFitHeight((short)1); 

ps.setFitWidth((short)1); 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



设置打印区域 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("Sheet1"); 

wb.setPrintArea(0, "$A$1:$C$2"); 

//为第一个Sheet页设置打印区域 

//也可以这样 

//wb.setPrintArea(0, 0, 1, 0, 0) ,详细参考java doc 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 

设置页脚的页数 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("format sheet"); 

HSSFFooter footer = sheet.getFooter() 



footer.setRight( "Page " + HSSFFooter.page() + " of " + HSSFFooter.numPages() ); 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



使用简便的函数 

这些函数保存在contrib并且提供了一些使用特征功能,例如设置合并单元格的边框,不用创建新样式改变样式属性。 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet1 = wb.createSheet( "new sheet" ); 



// 合并单元格 

HSSFRow row = sheet1.createRow( (short) 1 ); 

HSSFRow row2 = sheet1.createRow( (short) 2 ); 

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

cell.setCellValue( "This is a test of merging" ); 

Region region = new Region( 1, (short) 1, 4, (short) 4 ); 

sheet1.addMergedRegion( region ); 



// 设置边框和颜色. 

final short borderMediumDashed = HSSFCellStyle.BORDER_MEDIUM_DASHED;

HSSFRegionUtil.setBorderBottom( borderMediumDashed, 

region, sheet1, wb ); 

HSSFRegionUtil.setBorderTop( borderMediumDashed, 

region, sheet1, wb ); 

HSSFRegionUtil.setBorderLeft( borderMediumDashed, 

region, sheet1, wb ); 

HSSFRegionUtil.setBorderRight( borderMediumDashed, 

region, sheet1, wb ); 

HSSFRegionUtil.setBottomBorderColor(HSSFColor.AQUA.index, region, sheet1, wb); 

HSSFRegionUtil.setTopBorderColor(HSSFColor.AQUA.index, region, sheet1, wb); 

HSSFRegionUtil.setLeftBorderColor(HSSFColor.AQUA.index, region, sheet1, wb); 

HSSFRegionUtil.setRightBorderColor(HSSFColor.AQUA.index, region, sheet1, wb); 



// 展示HSSFCellUtil类的用法 

HSSFCellStyle style = wb.createCellStyle(); 

style.setIndention((short)4); 

HSSFCellUtil.createCell(row, 8, "This is the value of the cell", style); 

HSSFCell cell2 = HSSFCellUtil.createCell( row2, 8, "This is the value of the cell"); 

HSSFCellUtil.setAlignment(cell2, wb, HSSFCellStyle.ALIGN_CENTER); 



// 写入文件 

FileOutputStream fileOut = new FileOutputStream( "workbook.xls" ); 

wb.write( fileOut ); 

fileOut.close(); 



在Sheet页中上下移动行 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("row sheet"); 



//创建不同的行列 



// 将6-11行移动到0-5行 

sheet.shiftRows(5, 10, -5); 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



设置一个Sheet页为被选中的 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet = wb.createSheet("row sheet"); 

sheet.setSelected(true); 



// 创建不同的行列。。。 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



设置放大属性 

The zoom is expressed as a fraction. For example to express a zoom of 75% use 3 for the numerator and 4 for the denominator. 

Zoom被明确为一个分数,例如下面的75%使用3作为分子,4作为分母。 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet1 = wb.createSheet("new sheet"); 

sheet1.setZoom(3,4); // 75%放大 

FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



拆分和冻结窗口 

这里有你创建的两种窗口:冻结窗口和拆分窗口。 

一个冻结窗口是被行和列拆分开的,可以按照如下设置创建冻结窗口。 

sheet1.createFreezePane( 3, 2, 3, 2 ); 

前两个参数是你要用来拆分的列数和行数。后两个参数是下面窗口的可见象限,其中第三个参数是右边区域可见的左边列数,第四个参数是下面区域可见的首行。 

拆分可以将区域分成四个工作区。拆分发生在像素级别而且用户可以通过拖拽到新的位置来判断。 

用如下方式拆分窗口: 

sheet2.createSplitPane( 2000, 2000, 0, 0, HSSFSheet.PANE_LOWER_LEFT ); 

The first parameter is the x position of the split. This is in 1/20th of a point. A point in this case seems to equate to a pixel. The second parameter is the y position of the split. Again in 1/20th of a point. 

第一个参数是拆分的x位置。这里单位是一个点的1/20,在这种比例下点看起来是一个像素。第二个参数是拆分的y位置,也是一个点的1/20。第三、四个参数同上。最后一个参数说明当前哪个窗口有焦点,四个选择HSSFSheet.PANE_LOWER_LEFT, PANE_LOWER_RIGHT, PANE_UPPER_RIGHT or PANE_UPPER_LEFT。 

HSSFWorkbook wb = new HSSFWorkbook(); 

HSSFSheet sheet1 = wb.createSheet("new sheet"); 

HSSFSheet sheet2 = wb.createSheet("second sheet"); 

HSSFSheet sheet3 = wb.createSheet("third sheet"); 

HSSFSheet sheet4 = wb.createSheet("fourth sheet"); 



// 冻结第一行 

sheet1.createFreezePane( 0, 1, 0, 1 ); 

// 冻结第一列 

sheet2.createFreezePane( 1, 0, 1, 0 ); 

// 冻结列和行 

sheet3.createFreezePane( 2, 2 ); 

// 拆分窗口并且使左下方有焦点 

sheet4.createSplitPane( 2000, 2000, 0, 0, HSSFSheet.PANE_LOWER_LEFT ); 



FileOutputStream fileOut = new FileOutputStream("workbook.xls"); 

wb.write(fileOut); 

fileOut.close(); 



反复的行和列(设置打印标题) 

在打印输出的时候需要使用HSSFWorkbook类的setRepeatingRowsAndColumns()方法反复的设置行和列。 

这个方法包含5个参数,第一个参数是Sheet页的索引(从0开始算),第二、三个参数是重写的列的范围。不使用重写功能的话可以设置-1代替。第四、五个参数是重写的行的范围。不使用重写功能的话可以设置-1代替。 

HSSFWorkbook wb = new HSSFWorkbook();

分享到:
评论

相关推荐

    POI报表导出excel

    在这个“POI报表导出excel”的案例中,我们将深入探讨如何使用POI 3.6版本来实现报表的导出,包括设置Excel样式、合并单元格以及处理多表头的合并。 首先,我们需要了解Apache POI的核心组件:HSSFWorkbook(用于...

    POI生成Excel POI操作Excel POI读取Excel POI类库

    在这个场景中,我们关注的是如何使用POI来创建、读取和操作Excel文档。在Web项目中,这种功能通常用于数据导入导出,报表生成,或者任何需要与用户交换表格数据的场景。 **POI生成Excel** 生成Excel文件主要涉及...

    poi excel poi excel poi excel

    为了使用 POI 操作 Excel 文件,首先需要准备以下环境: 1. **JDK 版本**:至少需要 JDK 1.4 或更高版本。 2. **POI 库**:下载 POI 库,可以从 Apache 官方网站获取:...

    POI生成excel报表

    ### POI生成Excel报表知识点详解 #### 一、Apache POI简介 Apache POI是Apache软件基金会的一个开源项目,主要用于处理Microsoft Office格式...以上就是使用Apache POI生成Excel报表的主要知识点,希望对你有所帮助。

    POI报表Excel

    POI报表Excel

    POI操作Excel的封装

    在这个场景中,"POI操作Excel的封装"指的是对POI API进行的高级抽象和简化,以便于开发人员更方便地处理Excel文件。通过反射和约定,可以创建一个易于使用的API,隐藏底层复杂的POI细节。 反射是Java编程语言中的一...

    基于POI的Excel操作Java类

    为更方便的使用POI的API来操作Excel(2003)文件,对POI中针对Excel文件的读写进行了简单封装。此类中包含以下功能: 1.根据模板创建Excel文件 ...压缩包中包含POI的jar文件、POIExcel的jar文件及POIExcel的源码

    poi 操作excel模板

    通过以上步骤,你可以使用Apache POI有效地操作Excel模板,并将数据填充到新生成的文件中。这在报表生成、数据分析、批量导出等方面非常实用。记得在实际项目中,还要处理异常、优化性能,比如使用缓冲流、避免频繁...

    poi3.0.1操作excel

    在本案例中,我们将重点关注"poi3.0.1"版本如何操作Excel文件。这个版本的POI库提供了Java程序员处理Excel文档的强大功能,可以进行创建、读取、更新和删除等操作。 首先,我们需要理解Apache POI的工作原理。它...

    java使用POI操作excel (支持excel2007)

    Java 使用Apache POI库操作Excel 2007文件详解 在Java开发中,处理Excel文件是一项常见的任务,特别是对于数据分析、数据导入导出或报表生成等场景。Apache POI是一个流行的开源库,它允许开发者读写Microsoft ...

    Apache poi 操作 excel 文件压缩包

    5. **poi-examples**: 包含了使用Apache POI API的示例代码,可以帮助开发者理解如何实际操作Excel文件。 6. **poi-excelant**: 提供了用于构建和执行Ant任务的工具,这些任务与Excel操作有关,例如创建或处理Excel...

    Java 使用poi导入excel 并使用xml做数据验证

    导入数据库通常涉及JDBC(Java Database Connectivity),需要建立数据库连接,编写SQL语句,使用`PreparedStatement`来执行带有参数的插入操作,并确保事务的正确管理,以保证数据的一致性。如果所有数据都成功导入...

    POI技术简单应用开发报表简单使用

    **POI技术简单应用开发报表简单使用** Apache POI是一个流行的开源库,专门用于处理Microsoft Office格式的文件,如Excel、Word和PowerPoint。在Java编程环境中,它为开发者提供了强大的API,允许他们读取、写入和...

    Excel操作工具poi3.8

    《使用Apache POI 3.8进行Excel操作的详解》 Apache POI 是一个流行的开源项目,它允许Java开发者创建、修改和显示Microsoft Office格式的文件,尤其是Excel工作簿(.xlsx和.xls)。在给定的标题“Excel操作工具poi...

    “Java POI 模板”打造复杂Excel报表.pdf

    本文主要介绍了使用Java POI模板来生成复杂的Excel报表的方法。POI(Poor Obfuscation Implementation)是一个Java API,用于读取和写入Microsoft Office文件格式,包括Excel文件。 首先,需要设计Excel报表模板,...

    poi导入导出excel生成报表

    本篇文章将详细介绍如何使用 Apache POI 进行 Excel 文件的生成与读取操作。 #### 二、创建 Excel 文件 ##### 1. 导入必要的库 为了能够使用 Apache POI 的功能,首先需要导入相应的包: ```java import org....

    poi jxl 生成EXCEL 报表

    虽然POI功能更强大,但JXL在某些场景下可能更易于使用,尤其是对于简单的Excel操作。 - 创建Workbook实例,读取或新建Excel文件。 - 创建Sheet对象,对应Excel的工作表。 - 在Sheet上创建Row和Cell,填充数据。...

    使用poi从数据库导出excel表的示例

    可能包含了数据库连接的配置、SQL查询的测试、POI操作Excel的单元测试等。 在实际应用中,我们还需要考虑性能优化,比如使用PreparedStatement防止SQL注入,批量插入数据以减少数据库交互次数,以及合理设置内存...

    使用poi读取、写入复杂excel工具类(包含样式)

    使用poi读取写入复杂excel内容包括样式,工具类

Global site tag (gtag.js) - Google Analytics