Poi方法导出Excel文件
Poi导出Excel需要的jar包
解析2003版Excel。
Poi-3.10-FINAL-20140208.jar
Commons-codec-1.5.jar
Commons-logging-1.1.jar
Log4j-1.2.13.jar
解析2007版Excel。
Dom4j-1.6.1.jar
Stax-api-1.0.1.jar
Xmlbeans-2.3.0.jar
以上三个是第三方依赖插件
Poi-ooxml-3.10-FINAL-20140208.jar
Poi-ooxml-schemas-3.10-FINAL-20140208.jar
以下是导出Excel文件的方法
package com.sxt.poi;
import java.io.IOException;
import java.io.OutputStream;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFCellStyle;
import org.apache.poi.hssf.usermodel.HSSFFont;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.hssf.util.HSSFColor;
/**
* 导出Excel文件
*
* @author Administrator
*
*/
public class ExportExcel {
/**
* 文件导出方法.
* @param resource List<String[]> 集合类型, 要导出的具体数据集合.
* @param outputStream 输出流. 输出的excel文件保存的具体位置.
* @throws IOException
*/
public void exportExcel(List<String[]> resource, OutputStream outputStream)
throws IOException{
// 创建一个内存Excel对象.
HSSFWorkbook workbook = new HSSFWorkbook();
// 创建一个表格.
HSSFSheet sheet = workbook.createSheet("sheet1");
// 创建表头
// 获取表头内容.
String[] headerStr = resource.get(0);
HSSFRow headerRow = sheet.createRow(0);
// 设置列宽
for(int i = 0; i < headerStr.length; i++){
sheet.setColumnWidth(i, 5000);
}
// 设置头单元格样式
HSSFCellStyle headerStyle = workbook.createCellStyle();
headerStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
// 设置字体
HSSFFont headerFont = workbook.createFont();
headerFont.setColor(HSSFColor.VIOLET.index);
headerFont.setFontName("宋体");
headerStyle.setFont(headerFont);
// 定义表头内容.
for(int i = 0; i < headerStr.length; i++){
// 创建一个单元格
HSSFCell headerCell = headerRow.createCell(i);
headerCell.setCellStyle(headerStyle);
headerCell.setCellValue(headerStr[i]);
}
// 表体内容.
// 样式
HSSFCellStyle bodyStyle = workbook.createCellStyle();
bodyStyle.setAlignment(HSSFCellStyle.ALIGN_CENTER); // 水平居中
// 设置字体
HSSFFont bodyFont = workbook.createFont();
bodyFont.setColor(HSSFColor.BLUE.index);
bodyFont.setFontName("微软雅黑");
bodyStyle.setFont(bodyFont);
for(int row = 1; row < resource.size(); row++){
// 输出的行数据
String[] temp = resource.get(row);
// 创建行
HSSFRow bodyRow = sheet.createRow(row);
// 循环创建列
for(int cell = 0; cell < temp.length; cell++){
HSSFCell bodyCell = bodyRow.createCell(cell);
bodyCell.setCellStyle(bodyStyle);
bodyCell.setCellValue(temp[cell]);
}
}
// 将内存创建的excel对象,输出到文件中.
workbook.write(outputStream);
}
}
以下是导入Excel文件的方法
package com.sxt.poi;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDataFormat;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
/**
* 解析Excel文件
*
* @author Administrator
*
*/
public class ParseExcel {
/**
* 解析文件的方法.
* @param inputStream 文件输入流, 要解析的Excel文件输入流
* @param suffix 文件后缀名, xls或xlsx. 代码决定使用什么方式解析Excel.
* @param startRow 从第几行开始读取数据.
* @return List<String[]> 集合中的一个元素对应一行解析的数据.
* 元素为字符串数组类型. 数组中的每个元素对应一列数据.
* @throws IOException
*/
public List<String[]> parseExcel(InputStream inputStream, String suffix, int startRow)
throws IOException{
// 1. 定义excel对象变量
Workbook workbook = null;
// 2. 判断后缀.决定使用的解析方式. 决定如何创建具体的对象
if("xls".equals(suffix)){
// 2003
workbook = new HSSFWorkbook(inputStream);
//HSSFWorkbook是微软在推出Excel时候,完整命名的简写名,它是将Excel当成类似于表格或者数组来解析的。
//再用HSSFWorkbook的时候会出现异常,我们要将它抛出。IO异常(可能找不到文件)。
}else if("xlsx".equals(suffix)){
// 2007
workbook = new XSSFWorkbook(inputStream);
//再用HSSFWorkbook的时候会出现异常,我们要将它抛出。IO异常(可能找不到文件)。
}else{
// 未知内容
return null;
}
// 整个工作界面是workbook ,但是里面有若干个表。 获取工作表 excel分为若干个表. sheet
Sheet sheet = workbook.getSheetAt(0);
if(sheet == null){
//如果这个表为空时返回null。
return null;
}
// 获取表格中最后一行的行号
int lastRowNum = sheet.getLastRowNum();
// 最后一行的行号大于startRow
if(lastRowNum <= startRow){
return null;
}
List<String[]> result = new ArrayList<String[]>();
// 定义行变量和单元格变量
Row row = null;
Cell cell = null;
// 循环读取
for(int rowNum = startRow; rowNum <= lastRowNum; rowNum++){
row = sheet.getRow(rowNum);
// 获取当前行的第一列和最后一列的标记,因为Excel中每一列有A,B,C,D..标记。
short firstCellNum = row.getFirstCellNum();
short lastCellNum = row.getLastCellNum();
if(lastCellNum != 0){
String[] rowArray = new String[lastCellNum];
for(int cellNum = firstCellNum; cellNum < lastCellNum; cellNum++){
cell = row.getCell(cellNum);
// 判断单元格是否有数据
if(cell == null){
rowArray[cellNum] = null;
}else{
rowArray[cellNum] = parseCell(cell);
}
}
result.add(rowArray);
}
}
return result;
}
/**
* 解析单元格
* @return String 单元格数据
*/
private String parseCell(Cell cell){
String cellStr = null;
//设计一个单元格字符串
// 判断单元格的类型
switch(cell.getCellType()){
case HSSFCell.CELL_TYPE_STRING :
// 字符串类型单元格
cellStr = cell.getRichStringCellValue().toString();
break;
case HSSFCell.CELL_TYPE_BLANK :
// 空数据, 标准数据
cellStr = "";
break;
case HSSFCell.CELL_TYPE_NUMERIC :
// 数学类型. 数学类型包含日期,时间,数字
// 判断日期[年月日2016-11-17 | 时分10:00]类型
if(HSSFDateUtil.isCellDateFormatted(cell)){
// 判断具体类型, 是日期还是时间
SimpleDateFormat sdf = null;
if(cell.getCellType() == HSSFDataFormat.getBuiltinFormat("h:mm")){
// 时间
sdf = new SimpleDateFormat("HH:mm");
}else{
// 日期
sdf = new SimpleDateFormat("yyyy-MM-dd");
}
Date temp = cell.getDateCellValue();
cellStr = sdf.format(temp);
}else{
// 数字
double temp = cell.getNumericCellValue();
// 数学格式化工具
DecimalFormat format = new DecimalFormat();
// 查看单元格中的具体样式类型
String formatStr = cell.getCellStyle().getDataFormatString();
if(formatStr.equals("General")){
// 定义格式化正则. 使用具体有效数据进行个时候.且只保留有效数据.
format.applyPattern("#");
}
cellStr = format.format(temp);
}
break;
default :
cellStr = "";
}
return cellStr;
}
}