JAVA Excel 表格数据下载

Excel 下载工具类:

    public HttpServletResponse download(String path, HttpServletResponse response) {
        try {
            // path是指欲下载的文件的路径。
            File file = new File(path);
            // 取得文件名。
            String filename = file.getName();
            // 取得文件的后缀名。
            String ext = filename.substring(filename.lastIndexOf(".") + 1).toUpperCase();
            // 以流的形式下载文件。
            InputStream fis = new BufferedInputStream(new FileInputStream(path));
            byte[] buffer = new byte[fis.available()];
            fis.read(buffer);
            fis.close();
            // 清空response
            response.reset();
            // 设置response的Header
            response.addHeader("Content-Disposition", "attachment;filename=" + new String(filename.getBytes()));
            response.addHeader("Content-Length", "" + file.length());
            OutputStream toClient = new BufferedOutputStream(response.getOutputStream());
            response.setContentType("application/octet-stream");
            toClient.write(buffer);
            toClient.flush();
            toClient.close();
        } catch (IOException ex) {
            ex.printStackTrace();
        }
        return response;
    }

数据填充方法:

    @RequestMapping({ "/manage/datastatistical_show.htm" })
    public void datastatistical_show(HttpServletRequest request, HttpServletResponse response) {
        List<DataStatistical> dsList  =    this.dataStatisticalService.query("select obj from DataStatistical obj order by obj.addTime asc", null, -1, -1);
        List<String> header = new ArrayList<String>();
        header.add("用户名");
        header.add("开始时间");
        header.add("结束时间");
        header.add("店铺名称");
        header.add("店员名称");
        header.add("访问内容");
        List<Map> data = new ArrayList<Map>();
                for (DataStatistical ds:dsList) {
                    Map<String, String> map = new HashMap<>();
                    map.put("用户名",   ds.getUser().getUserName());
                    map.put("开始时间", ds.getBeginTime().toString());
                    map.put("结束时间", ds.getEndTime().toString());
                    map.put("店铺名称", (ds.getStore()==null)?null:ds.getStore().getStore_name());
                    map.put("店员名称", (ds.getClerkuser()==null)?null:ds.getClerkuser().getUser().getUserName());
                    map.put("访问内容", ds.getLook_type());
                    data.add(map);
                }
        String path="";
        try {
              String realPath=request.getRealPath("/");
              path=realPath+"/download/"+UUID.randomUUID()+".xls";
            ExcelFileUtils.OutputExcel(path,header, data);
        } catch (Exception e) {
            // TODO Auto-generated catch block
            e.printStackTrace();
        }
        new OrderSellerAction().download(path, response);
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java可以使用EasyExcel框架将数据下载Excel表格。EasyExcel是阿里巴巴开源的一个Excel处理框架,以使用简单、节省内存著称。它能够快速、简洁地解决大文件内存溢出的问题,让你在不用考虑性能和内存等因素的情况下,快速完成Excel的读取和写入等功能。 使用EasyExcel进行下载数据Excel表格的步骤如下: 1. 引入EasyExcel的依赖:在你的Java项目中,需要添加EasyExcel的依赖,可以通过Maven或Gradle进行添加。 2. 创建ExcelWriter对象:使用EasyExcelAPI,创建一个ExcelWriter对象,用于写入数据Excel表格。 3. 定义Excel表格的表头:通过ExcelWriter对象的write方法,传入表头数据,并指定表格的sheet名称和表头的类型。 4. 写入数据行:使用ExcelWriter对象的write方法,传入数据行的集合,将数据写入到Excel表格数据区域。 5. 关闭ExcelWriter对象:在写入完数据后,需要关闭ExcelWriter对象,以释放相关资源。 这样,你就可以通过Java使用EasyExcel框架下载数据Excel表格了。详细的使用方法可以参考EasyExcel官方文档提供的示例和文档。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [使用java解析和读取excel表格(EasyExcel的简单使用)](https://blog.csdn.net/weixin_72979483/article/details/128676578)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *3* [48、数据导出到Excel(easyExcel)](https://blog.csdn.net/qq_45695621/article/details/128403615)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值