java操作excel文件基础架构实现,支持2007以上版本

本文介绍了使用Apache POI库进行Java操作Excel文件的基础实现,特别强调了POI支持Excel2007及以上版本。内容包括POI的不同组件如HSSF、XSSF等,以及如何处理Excel中的单元格和工作表。
摘要由CSDN通过智能技术生成

转载请注明出处:http://blog.csdn.net/xiaojimanman/article/details/22800915

java操作office文件现在主流的jar包有jxl和POI,由于目前jxl.jar没有人更新,并不支持Excel2007及其以上版本,Apache POI是Apache软件基金会的开放源码函式库,POI提供API给Java程序对Microsoft Office格式档案读和写的功能。

POI结构如下:

HSSF - 提供读写Microsoft Excel格式档案的功能。
XSSF - 提供读写Microsoft Excel OOXML格式档案的功能。
HWPF - 提供读写Microsoft Word格式档案的功能。
HSLF - 提供读写Microsoft PowerPoint格式档案的功能。
HDGF - 提供读写Microsoft Visio格式档案的功能。

下面就简单介绍一下POI对Excel文件操作的一些基础实现。在下面的实现中,均将Excel文件中单元格数据认为是字符串。

表格中单元格java bean

 /**  
 *@Description: Excel单元格格式
 */ 
package cn.lulei.office.model;  

public class ExcelCell {
	private int row;//行
	private int column;//列
	private String content;//内容
	
	public int getRow() {
		return row;
	}
	public void setRow(int row) {
		this.row = row;
	}
	public int getColumn() {
		return column;
	}
	public void setColumn(int column) {
		this.column = column;
	}
	public String getContent() {
		return content;
	}
	public void setContent(String content) {
		this.content = content;
	}
}

表格中工作表 java bean

 /**  
 *@Description: Excel表格sheet页数据
 */ 
package cn.lulei.office.model;  

import java.util.List;
  
public class ExcelSheet {
	private String sheetName;
	private List<ExcelCell> cells;
	
	public String getSheetName() {
		return sheetName;
	}
	public void setSheetName(String sheetName) {
		this.sheetName = sheetName;
	}
	public List<ExcelCell> getCells() {
		return cells;
	}
	public void setCells(List<ExcelCell> cells) {
		this.cells = cells;
	}
}


 Excel2003以前版本文件操作

 /**  
 *@Description:  Excel2003之前版本操作
 */ 
package cn.lulei.office.v2003;  

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import cn.lulei.office.model.ExcelCell;
import cn.lulei.office.model.ExcelSheet;
  
public class Excel {
	private static final String excelFileSuffix = ".xls";//Excel文件后缀名
	private static final String defaultSheetName = "Sheet";//默认sheet名
	
	/**
	 * @param sheets
	 * @param fileName
	 * @return
	 * @Date:2014-4-1  
	 * @Author:lulei  
	 * @Description: 生成Excel文件
	 */
	public boolean create(List<ExcelSheet> sheets, String fileName) {
		if (sheets == null) {
			throw new NumberFormatException("sheets is null");
		}
		if (fileName == null || "".equals(fileName)) {
			throw new NumberFormatException("fileName is null");
		}
		try {
			//判断后缀名是否是 xls
			fileName = fileName.toLowerCase().endsWith(excelFileSuffix) ? fileName : fileName + exce
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值