java web下载 Excel文件

1、在 response(HttpServletResponse类型)设置返回的类型:

res.setContentType("application/x-download");
res.setHeader(
       "Content-disposition",
       "attachment;filename="
               + fileName);//其中 fileName 是个变量值

2、获取 输出流

OutputStream outs=res.getOutputStream();

3、获取Excel文件数据流源

//writeList2Excel方法接收一个map的list集合,可将map的key值作为表列名,value值作为表格的值生成Excel,具体方法见下实现类

HSSFWorkbook excel=DataReadedInExcel.writeList2Excel(list);

4、输出Excel的数据流

excel.write(outs);


参考类:

public class DataReadedInExcel {

public static HSSFWorkbook writeList2Excel(List list){
//创建操作Excel的HSSFWorkbook对象
HSSFWorkbook excel= new HSSFWorkbook();
//Excel中的一个sheet(工作表)对应着java中的一个HSSFSheet对象,利用HSSFWorkbook对象可以创建一个HSSFSheet对象
HSSFSheet sheet = excel.createSheet("sheet1");
//给表格添加表头
createFirstRow(sheet.createRow(0),(Map)list.get(0));
//给表格添加内容
createContextRow(sheet,list);

return excel;
}
public static void createFirstRow(HSSFRow firstRow,Map firstCellNames){
Set keys=firstCellNames.keySet();
Iterator it=keys.iterator();
int i=0;
while(it.hasNext()){
Object obj=it.next();
if(obj instanceof String)
firstRow.createCell(i).setCellValue((String)obj);
else if (obj instanceof BigDecimal)
firstRow.createCell(i).setCellValue(((BigDecimal)obj).intValue());
else if (obj==null)
firstRow.createCell(i).setCellValue("null");
else 
firstRow.createCell(i).setCellValue("");
i++;
}
}
public static void createContextRow(HSSFSheet sheet,List list){
for(int i=0;i<list.size();i++){
HSSFRow row=sheet.createRow(i+1);
Map map=(Map)list.get(i);
Collection collection=map.values();
Iterator it = collection.iterator();
int j=0;
while(it.hasNext()){
Object obj=it.next();
if(obj instanceof String)
row.createCell(j).setCellValue((String)obj);
else if (obj instanceof BigDecimal)
row.createCell(j).setCellValue(((BigDecimal)obj).intValue());
else if (obj==null)
row.createCell(j).setCellValue("null");
else 
row.createCell(j).setCellValue("");
j++;
}
}
}

}

jar包依赖配置:

<!-- Excel的读写 -->
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.5-FINAL</version>
</dependency>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值