springmvc 输出流导出

@RequestMapping(value = "/exportExcel")
@ResponseBody
public void exportExcel(WebRequest webRequest, Parameter parameter,
User user,@RequestParam("trdCode") String trdCode,
@RequestParam("name") String name, HttpServletResponse response) {
EleTabBusAcc etba =new EleTabBusAcc();
etba.setId(trdCode);
etba.setTrdNam(name);
String fileName = "Merchant information";
response.reset();
response.setContentType("application/octet-stream;charset=GBK");// 不同类型的文件对应不同的MIME类型
response.setHeader("content-disposition", "attachment;filename="
+ fileName + ".csv");
PrintWriter out = null;
try {
out = response.getWriter();
parameter.setPage(1);
parameter.setRows(500);
int retInt = eleTabService.exportExcel(etba, out, parameter,
0);
System.out.println("exportDatstatExcel=" + retInt);
} catch (Exception e) {
e.printStackTrace();
} finally {
if (null != out) {
out.flush();
out.close();
}
}

}



       @Override
public int exportExcel(EleTabBusAcc etba, PrintWriter out,
Parameter parameter, int retInt) {
SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
if (retInt == 0) {
out.write("商户号,商户名,mcc,商户分类编码,商户分类名称,创建时间\r\n");
}
Grid<EleTabBusAcc> grip = queryBusAcc(parameter, etba);
if (null != grip) {


List<EleTabBusAcc> page = grip.getRows();
if (page.size() > 0) {
int idx = 0;
for (EleTabBusAcc obj : page) {
StringBuilder sb = new StringBuilder();
sb.append("\"");
sb.append(obj.getId());
sb.append("\",");
sb.append("\"");
sb.append(obj.getTrdNam());
sb.append("\",");
sb.append("\"");
sb.append(obj.getMcc());
sb.append("\",");
sb.append("\"");
sb.append(obj.getBusCod());
sb.append("\",");
sb.append("\"");
sb.append(obj.getBusNam());
sb.append("\",");
sb.append("\"");
sb.append(sdf.format(obj.getCreDat()));
sb.append("\"\r\n");
out.write(sb.toString());
idx++;
}
retInt = retInt + idx;
if (idx < 10000) {
parameter.setPage(parameter.getPage() + 1);
parameter.setRows(500);
retInt = exportExcel(etba, out, parameter, retInt);
}
}
}
return retInt;
}





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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值