excel导入导出的功能现在在后台管理的系统中越来越常见,比如导出学生信息、导出商品的信息。但是并不是每次导出都使用所
有的字段,可能是用户自定义导出字段,所以这时候就需要个性化导出设置配置。
主要介绍excel的导出模板
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
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.HSSFRichTextString;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import com.lwl.domain.pay.TradeRecord;
/**
* excel 的工具类
* @author liuwielong@zhicall.com
*
*/
@SuppressWarnings("deprecation")
public class ExcellUtil{
/**
* 指定文件导出位置,导出excel
* @param sheetTitle sheet名称
* @param headers excel表头
* @param dataset 数据
* @param filePath 文件路径
* @param fields 需要导出的字段【TradeRecord中对应的字段】
* @return
* @author liuweilong@zhicall.com
* @create 2016-5-18 上午10:08:19
*/
public static boolean exportExcel(String sheetTitle, String[] headers,
List<TradeRecord> dataset, String filePath, String[] fields) {
OutputStream out = null;
try {
out = new FileOutputStream(filePath);
} catch (FileNotFoundException e1) {
e1.printStackTrace();
return false;
}
return exportExcelByOS(sheetTitle, headers, dataset, out, fields);
}
/**
* 通过传入流生成excel
* @param sheetTitle sheet名称
* @param headers excel表头
* @param dataset 数据
* @param out 流
* @param fields 需要导出的字段【TradeRecord中对应的字段】
* @return
* @author liuweilong@zhicall.com
* @create 2016-5-18 上午10:07:04
*/
public static boolean exportExcelByOS(String sheetTitle, String[] headers,
List<TradeRecord> dataset, OutputStream out, String[] fields) {
boolean flag = true;
// 声明一个工作薄
HSSFWorkbook workbook = new HSSFWorkbook();
// 生成一个表格
HSSFSheet sheet = workbook.createSheet(sheetTitle);
// 设置表格默认列宽度为15个字节
sheet.setDefaultColumnWidth((short) 15);
// 生成一个样式
// HSSFCellStyle style = workbook.createCellStyle();
// 设置这些样式
// style.setFillForegroundColor(HSSFColor.SKY_BLUE.index);
// style.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
// style.setBorderBottom(HSSFCellStyle.BORDER_THIN);
// style.setBorderLeft(HSSFCellStyle.BORDER_THIN);
// style.setBorderRight(HSSFCellStyle.BORDER_THIN);
// style.setBorderTop(HSSFCellStyle.BORDER_THIN);
// style.setAlignment(HSSFCellStyle.ALIGN_CENTER);
// 生成一个字体
// HSSFFont font = workbook.createFont();
// font.setColor(HSSFColor.VIOLET.index);
// font.setFontHeightInPoints((short) 12);
// font.setBoldweight(HSSFFont.BOLDWEIGHT_BOLD);
// 把字体应用到当前的样式
// style.setFont(font);
// 生成并设置另一个样式
// HSSFCellStyle style2 = workbook.createCellStyle();
// style2.setFillForegroundColor(HSSFColor.LIGHT_YELLOW.index);
// style2.setFillPattern(HSSFCellStyle.SOLID_FOREGROUND);
// style2.setBorderBottom(HSSFCellStyle.BORDER_THIN);
// style2.setBorderLeft(HSSFCellStyle.BORDER_THIN);
// style2.setBorderRight(HSSFCellStyle.BORDER_THIN);
// style2.setBorderTop(HSSFCellStyle.BORDER_THIN);
// style2.setAlignment(HSSFCellStyle.ALIGN_CENTER);
// style2.setVerticalAlignment(HSSFCellStyle.VERTICAL_CENTER);
// 生成另一个字体
// HSSFFont font2 = workbook.createFont();
// font2.setBoldweight(HSSFFont.BOLDWEIGHT_NORMAL);
// 把字体应用到当前的样式
// style2.setFont(font2);
// 声明一个画图的顶级管理器
// HSSFPatriarch patriarch = sheet.createDrawingPatriarch();
// 定义注释的大小和位置,详见文档
// HSSFComment comment = patriarch.createComment(new HSSFClientAnchor(0,
// 0, 0, 0, (short) 4, 2, (short) 6, 5));
// 设置注释内容
// comment.setString(new HSSFRichTextString("可以在POI中添加注释!"));
// 设置注释作者,当鼠标移动到单元格上是可以在状态栏中看到该内容.
// comment.setAuthor("leno");
// 产生表格标题行
HSSFRow row = sheet.createRow(0);
int index = 0;
//如果传入的表头是空或者长度为0 则 不需要表头
if(headers==null||headers.length==0){
index = -1;
}else{
for (short i = 0; i < headers.length; i++) {
HSSFCell cell = row.createCell(i);
// cell.setCellStyle(style);
HSSFRichTextString text = new HSSFRichTextString(headers[i]);
cell.setCellValue(text);
}
}
if(dataset!=null){
//循环集合
for (TradeRecord info : dataset) {
info.setName(info.getName());
info.setCardNo(info.getCardNo());
info.setRecordStatusName(info.getRecordStatusName());
index++;
row = sheet.createRow(index);
for (int i = 0; i < fields.length; i++) {
HSSFCell cell = row.createCell(i);
// cell.setCellStyle(style2);
cell.setCellValue(getFieldValue(info,fields[i]));//实现了动态封装数据
}
}
}
try {
workbook.write(out);
} catch (IOException e) {
flag = false;
e.printStackTrace();
}finally{
if(out!=null){
try {
out.close();
out = null;
} catch (IOException e) {
e.printStackTrace();
}
}
}
return flag;
}
<span style="white-space:pre"> </span>/**
* 根据字段名称 获取对象中改字段的值
* @param obj 对象
* @param fieldName 字段
* @return
* @author liuweilong@zhicall.com
* @create 2016-5-17 下午1:04:19
*/
public static String getFieldValue(Object obj,String fieldName) {
String value = null;
if (obj == null) return null;
Field[] fields = obj.getClass().getDeclaredFields();
for (int j = 0; j < fields.length; j++) {
fields[j].setAccessible(true);
if(fieldName.equals(fields[j].getName())){
//改字段的类型
String className = fields[j].getType().getName();
try {
//如果是日期类型 则转化
if(className.equalsIgnoreCase("Date")||className.equalsIgnoreCase("java.util.Date")){
Date time = (Date) fields[j].get(obj);
value = DateUtil.formatDate("yyyy-MM-dd HH:mm:ss", time);
}else if(className.equalsIgnoreCase("PayPlatform")||className.equalsIgnoreCase("com.zhicall.balance.enums.PayPlatform")){
PayPlatform pay = (PayPlatform) fields[j].get(obj);
value = pay.getPayPlayformCode();
}else{
value = fields[j].get(obj)+"";
}
} catch (IllegalArgumentException e) {
e.printStackTrace();
} catch (IllegalAccessException e) {
e.printStackTrace();
}
}
}
return value;
}
excel导出模板已经写好,至于如果你想修改导出的样式、背景色、字体什么的属性,可以打开注释掉的代码自行设置。那接下来我们看看怎么调用它。
ExcellUtil.exportExcel( sheetTitle, headers, dataset, filePath, fields); ExcellUtil. exportExcelByOS(sheetTitle, headers, dataset, out, fields);
这2个方法的主要差距就至于你是否提前知道文件的具体的路径,如果已经有文件的流则直接调用第二个方法,如果没有就先 调用第一个然后 会转化调用第二个,为什么把第一个方法的文件流放在ExcellUtil中实现而不放在外部实现,这样就可以
只写 一 个方法呢?因为如果你把它挪 到外面实现,如果有十处要导出功能,你自己是不是要写十遍这样的文件流呢?还有就
是该 功能 属于谁的范畴,显然是属于excel的,外部不需 要关系你内部怎么实现,只需要按照规定的格式给你传入数据,调用
接口 或者方 法返回数据给调用者即可,调用者只关心返回的结果集。