xssf和hssf的区别java_apache POI 的 HSSF和XSSF

Apache POI是一个用于处理Microsoft Office文件的Java库。HSSF是处理.xls格式(Excel 2003及之前版本)的API,而XSSF则是处理.xlsx格式(Excel 2007及以上版本)的API。本文介绍了如何使用HSSF和XSSF在Java中创建、设置样式和内容。
摘要由CSDN通过智能技术生成

转自:http://blog.sina.com.cn/s/blog_717c2b0f0100wcef.html

没工夫看先放着

还有几个不错的:

POI 是 Apache 下的 Jakata 项目的一个子项目,主要用于提供 java 操作 Microsoft

Office 办公套件如 Excel,Word,Powerpoint 等文件的 API.

微软的Office 办公软件在企业的日常办公中占据着重要的地位,人们已经非常熟悉

Office 的使用。在我们开发的应用系统中,常常需要将数据导出到 Excel 文件中,或者

Word 文件中进行打印。比如移动的话费查询系统中就提供了将话费清单导入到 excel 表

格中的功能。这样在web 应用中,我们在浏览器中看到的数据可以被导出到 Excel 中了。

Excel 文件: xls 格式文件对应 POI API 为 HSSF 。 xlsx 格式为 office 2007 的文件格式,POI 中对应的API 为XSSF

Word 文件:doc 格式文件对应的 POI API 为 HWPF。 docx 格式为 XWPF

powerPoint 文件:ppt 格式对应的 POI API 为 HSLF。 pptx 格式为 XSLF

outlook :对应的 API 为 HSMF

Visio: 对应的 API 为 HDGF

Publisher : 对应的 API 为 HPBF

Apache POI HSSF和XSSF读写EXCEL总结

HSSF是指2007年以前的,XSSF是指2007年版本以上的

这个还是比较好用的,这些总结来自Apache的官方向导的点点滴滴

还有好多没有没有写的,详细的请参考http://poi.apache.org/spreadsheet/quick-guide.html

Java代码

public class SummaryHSSF {

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

//创建Workbook对象(这一个对象代表着对应的一个Excel文件)

//HSSFWorkbook表示以xls为后缀名的文件

Workbook wb = new HSSFWorkbook();

//获得CreationHelper对象,这个应该是一个帮助类

CreationHelper helper = wb.getCreationHelper();

//创建Sheet并给名字(表示Excel的一个Sheet)

Sheet sheet1 = wb.createSheet("HSSF_Sheet_1"); Sheet sheet2 = wb.createSheet("HSSF_Sheet_2");

//Row表示一行Cell表示一列

Row row = null;

Cell cell = null;

for(int i=0;i<60;i=i+2){

//获得这个sheet的第i行

row = sheet1.createRow(i);

//设置行长度自动 //row.setHeight((short)500);

row.setHeightInPoints(20);

//row.setZeroHeight(true);

for(int j=0;j<25;j++){ //设置每个sheet每一行的宽度,自动,根据需求自行确定

sheet1.autoSizeColumn(j+1, true);

//创建一个基本的样式

CellStyle cellStyle = SummaryHSSF.createStyleCell(wb);

//获得这一行的每j列

cell = row.createCell(j);

if(j==0){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

//先创建字体样式,并把这个样式加到单元格的字体里面

cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle); //给单元格设值

cell.setCellValue(true);

}else if(j==1){

//设置文字在单元格里面的位置

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

//设置这个样式的格式(Format)

cellStyle = SummaryHSSF.setCellFormat(helper,cellStyle, "#,##0.0000"); //先创建字体样式,并把这个样式加到单元格的字体里面

cellStyle.setFont(createFonts(wb));

//把这个样式加到单元格里面

cell.setCellStyle(cellStyle);

//给单元格设值

cell.setCellValue(new Double(2008.2008));

}else if(j==2){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER); cellStyle.setFont(createFonts(wb));

cell.setCellStyle(cellStyle);

cell.setCellValue(helper.createRichTextString("RichString"+i+j)); }else if(j==3){

cellStyle = SummaryHSSF.setCellStyleAlignment(cellStyle, CellStyle.ALIGN_CENTER, CellStyle.VERTICAL_CENTER);

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值