导出Excel文件

这篇博客介绍了如何利用POI库将查询到的数据导出为Excel文件,并通过设置响应头及输出流实现客户端的文件下载。操作步骤包括查询数据、创建Excel对象、设置标题行和数据行,最后通过输出流返回给浏览器。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

导出Excel文件


整体思路:

通过POI将查询到的数据写到Excel文件中, 通过输出流将文件写回客户端进行文件下载

具体的操作:
  • 查询所需要的导出的数据
  • 创建一个Excel对象
  • 在sheet页中创建标题行对象
  • 填写标题行的数据
  • 创建数据行对象
  • 填写数据行的数据
  • 设置响应头,编写下载文件的文件名
  • 通过输出流将Excel数据写回浏览器

        List<SubArea> subAreas = subAreaDao.findAll();

        if (subAreas != null && subAreas.size() > 0) {
            HSSFWorkbook workbook = new HSSFWorkbook();
            HSSFSheet sheet = workbook.createSheet("分区数据显示");
            HSSFRow row = sheet.createRow(0);
            row.createCell(0).setCellValue("编号");
            row.createCell(1).setCellValue("分区起始号");
            row.createCell(2).setCellValue("分区终止号");
            row.createCell(3).setCellValue("分区关键字");
            row.createCell(4).setCellValue("辅助关键字");
            row.createCell(5).setCellValue("区域信息");
            for (SubArea subArea : subAreas) {
                HSSFRow valuerow = sheet.createRow(sheet.getLastRowNum() + 1);
                valuerow.createCell(0).setCellValue(subArea.getId());
                valuerow.createCell(1).setCellValue(subArea.getStartNum());
                valuerow.createCell(2).setCellValue(subArea.getEndNum());
                valuerow.createCell(3).setCellValue(subArea.getKeyWords());
                valuerow.createCell(4).setCellValue(subArea.getAssistKeyWords());
                valuerow.createCell(5).setCellValue(subArea.getArea().getName());
            }
            String filename = "分区数据.xls";
            String agent = (String) ServletActionContext.getRequest().getHeader("User-Agent");
            String newFileName = FileUtils.encodeDownloadFilename(filename, agent);
            // 通过输出流将excel数据写回浏览器
            ServletOutputStream outputStream = ServletActionContext.getResponse().getOutputStream();
            ServletActionContext.getResponse().setContentType("application/vnd.ms-excel;charset=UTF-8");
            ServletActionContext.getResponse().setHeader("content-disposition", "filename=" + newFileName);
            workbook.write(outputStream);
            workbook.close();
        }

FileUtils

package com.lyric.bos.utils;

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

import sun.misc.BASE64Encoder;

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;
        }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值