POI导出,开发中经常会遇到数据导出这样的问题,下面是我在开发中采用的解决方法,大家可以参考,具体的实现害的结合你自身的业务逻辑...

@RequestMapping(value = "/drawPayFailExport",method = RequestMethod.GET,produces = "application/json")
public ResponseData getAllDrawPayFailExport(HttpServletRequest request, HttpServletResponse response){
String startTime = null;
String endTime = null;
String userName = null;
String accountNumber = null;
if (!"undefined".equals(request.getParameter("startTime"))){
startTime = request.getParameter("startTime");
}
if (!"undefined".equals(request.getParameter("endTime"))){
endTime = request.getParameter("endTime");
}
if (StringUtils.isNotBlank(request.getParameter("userName"))){
userName = request.getParameter("userName");
}
if (StringUtils.isNotBlank(request.getParameter("accountNumber"))){
accountNumber = request.getParameter("accountNumber");
}
DrawPayFailDto drawPayFailDto = new DrawPayFailDto();
drawPayFailDto.setStartTime(startTime);
drawPayFailDto.setEndTime(endTime);
drawPayFailDto.setUserName(userName);
drawPayFailDto.setAccountNumber(accountNumber);
logger.info("兑换提现付款失败导出请求参数:"+JSON.toJSON(drawPayFailDto));
//第一步创建workbook
HSSFWorkbook wb = new HSSFWorkbook();

//第二步创建sheet
HSSFSheet sheet = wb.createSheet("兑换提现付款失败表");

//第三步创建行row:添加表头0行
HSSFRow row = sheet.createRow(0);
HSSFCellStyle style = wb.createCellStyle();
style.setAlignment(HSSFCellStyle.ALIGN_CENTER); //居中

//第四步创建单元格
HSSFCell cell = row.createCell(0); //第一个单元格
cell.setCellValue("序号"); //设定值
cell.setCellStyle(style); //内容居中

cell = row.createCell(1); //第二个单元格
cell.setCellValue("申请编号");
cell.setCellStyle(style);

cell = row.createCell(2); //第三个单元格
cell.setCellValue("申请时间");
cell.setCellStyle(style);

cell = row.createCell(3); //第四个单元格
cell.setCellValue("用户姓名");
cell.setCellStyle(style);

cell = row.createCell(4); //第五个单元格
cell.setCellValue("手机号");
cell.setCellStyle(style);

cell = row.createCell(5); //第六个单元格
cell.setCellValue("实际应付金额");
cell.setCellStyle(style);

cell = row.createCell(6); //第七个单元格
cell.setCellValue("退款银行");
cell.setCellStyle(style);

cell = row.createCell(7); //第八个单元格
cell.setCellValue("银行卡号");

cell.setCellStyle(style);

 

cell = row.createCell(8);//第九个单元格

cell.setCellValue("初审人");

cell.setCellStyle(style);

 

cell = row.createCell(9); //第十个单元格

cell.setCellValue("复审人");

cell.setCellStyle(style);

 

cell = row.createCell(10); //第十一个单元格

cell.setCellValue("支付渠道");

cell.setCellStyle(style);

 

cell = row.createCell(11); //第十二个单元格

cell.setCellValue("付款状态");

cell.setCellStyle(style);

ResponseData responseData = refundTicketDrawService.selectDrawPayFailList(drawPayFailDto);

List<DrawConfirmDetailVo> list = null;

if ("0".equals(responseData.getStatus())){

  list = (List<DrawConfirmDetailVo>) responseData.getData();

}

if (list != null && list.size() > 0){

   for (int i = 0; i < list.size(); i++){

     DrawConfirmDetailVo drawConfirmDetailVo = list.get(i); //创建行

    row = sheet.createRow(i+1); //创建单元格并且添加数据

    row.createCell(0).setCellValue(i+1);

    row.createCell(1).setCellValue(drawConfirmDetailVo.getApplyNo());

    row.createCell(2).setCellValue(drawConfirmDetailVo.getApplytime());

    row.createCell(3).setCellValue(drawConfirmDetailVo.getRealName());

    row.createCell(4).setCellValue(drawConfirmDetailVo.getAccountNumber());

    row.createCell(5).setCellValue(String.valueOf(drawConfirmDetailVo.getActualMoney()));

    row.createCell(6).setCellValue(drawConfirmDetailVo.getBankName());

    row.createCell(7).setCellValue(drawConfirmDetailVo.getBankAccount());

    row.createCell(8).setCellValue(drawConfirmDetailVo.getFirstAuditPerson());

    row.createCell(9).setCellValue(drawConfirmDetailVo.getSecondAuditPerson());

    row.createCell(10).setCellValue(drawConfirmDetailVo.getPayChannel());

   if (drawConfirmDetailVo.getPayState() == 0){

     row.createCell(11).setCellValue(PayState.Pay_wait.getDesc());

   } else if (drawConfirmDetailVo.getPayState() == 1){

    row.createCell(11).setCellValue(PayState.Pay_success.getDesc());

   }else if (drawConfirmDetailVo.getPayState() == 2){

     row.createCell(11).setCellValue(PayState.Pay_fail.getDesc());

   }else if (drawConfirmDetailVo.getPayState() == 3){

    row.createCell(11).setCellValue(PayState.Pay_ing.getDesc());

}

}

}

  //web浏览通过MIME类型判断文件是excel类型

  response.setContentType("application/vnd.ms-excel;charset=utf-8");

  response.setCharacterEncoding("utf-8");

 

   //第六步将生成excel文件保存到指定路径下

   try { //FileOutputStream fout = new FileOutputStream("D:\\MediaPos.xls");

      String fileName = URLEncoder.encode("兑换提现付款失败表.xls");

     response.setHeader("Content-disposition", "attachment;filename=" + fileName);

     OutputStream fout = response.getOutputStream(); wb.write(fout); fout.close();

  } catch (IOException e) {

   logger.error("导出兑换提现付款失败表出错",e);

}

    return null;

}

转载于:https://www.cnblogs.com/chaiming520/p/9609743.html

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值