数据导出到xls后缀的文件中

//生成excel文件,xls后缀
        HSSFWorkbook workbook=new HSSFWorkbook();
        HSSFSheet sheet=workbook.createSheet("运单记录");
        //得到首行
        HSSFRow headRow=sheet.createRow(0);
        //设置首行列信息
        headRow.getCell(0).setCellValue("运单号");
        headRow.getCell(1).setCellValue("寄件人");
        headRow.getCell(2).setCellValue("寄件人电话");
        headRow.getCell(3).setCellValue("寄件人地址");
        headRow.getCell(4).setCellValue("收件人");
        headRow.getCell(5).setCellValue("收件人电话");
        headRow.getCell(6).setCellValue("收件人地址");
        
        //遍历数据集合,将数据赋值到xls表格内
        for (WayBill wayBill : wayBills) {
            //创建行
            HSSFRow row=sheet.createRow(sheet.getLastRowNum()+1);
            row.getCell(0).setCellValue(wayBill.getWayBillNum());
            row.getCell(1).setCellValue(wayBill.getSendName());
            row.getCell(2).setCellValue(wayBill.getSendMobile());
            row.getCell(3).setCellValue(wayBill.getSendAddress());
            row.getCell(4).setCellValue(wayBill.getRecName());
            row.getCell(5).setCellValue(wayBill.getRecMobile());
            row.getCell(6).setCellValue(wayBill.getRecAddress());
        }
        
        //下载导出
        //设置头信息
        ServletActionContext.getResponse().setContentType("application/vnd.ms-excel");
        String filename="运单数据.xls";
        //获取服务器浏览器类型
        String agent=ServletActionContext.getRequest().getHeader("user-agent");
        //返回处理中文乱码后的filename
        filename=FileUtils.encodeDownloadFilename(filename, agent);
        //文件命名
        ServletActionContext.getResponse().setHeader("Content-Disposition", "attachment; filename="+filename);
        //复制文件
        //输出流
        ServletOutputStream outputStream=ServletActionContext.getResponse().getOutputStream();
        workbook.write(outputStream);
        //关闭

        workbook.close();

附加上使用的工具类:

import java.io.IOException;
import java.net.URLEncoder;

import sun.misc.BASE64Encoder;

@SuppressWarnings("all")
public class FileUtils {
        /**
         * 下载文件时,针对不同浏览器,进行附件名的编码
         *
         * @param filename
         *            下载文件名
         * @param agent
         *            客户端浏览器
         * @return 编码后的下载附件名
         * @throws IOException
         */
        public static String encodeDownloadFilename(String filename, String agent)
                throws IOException {
            if (agent.contains("Firefox")) { // 火狐浏览器
                filename = "=?UTF-8?B?"
                        + new BASE64Encoder().encode(filename.getBytes("utf-8"))
                        + "?=";
                filename = filename.replaceAll("\r\n", "");
            } else { // IE及其他浏览器
                filename = URLEncoder.encode(filename, "utf-8");
                filename = filename.replace("+"," ");
            }
            return filename;
        }
}


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值