转载请注明出处: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;
}
}
/**
*@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