iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > JAVA >Java 使用hutool工具进行导出导入excel表格(代码很简单)
  • 303
分享到

Java 使用hutool工具进行导出导入excel表格(代码很简单)

javaexcel开发语言 2023-09-24 16:09:12 303人浏览 八月长安
摘要

1.先引入hutool的相关依赖                      cn.hutool            hutool-all            5.8.4                            org.ap

1.先引入hutool的相关依赖

                     cn.hutool            hutool-all            5.8.4                            org.apache.poi            poi-ooxml            4.1.2        

2.导出 

创建一个Controller进行测试 

    @GetMapping(path = "/export")    public void export(httpservletResponse response,OrderPageRequest orderPageRequest)throws ioException { {            // 查询导出订单数据            List ordereList = getOrdereList(orderPageRequest);            if (CollectionUtils.isEmpty(ordereList)) {                throw new BusinessException("暂无数据!");            }            //在内存操作,写到浏览器            excelWriter writer = ExcelUtil.getWriter(true);            //自定义标题别名            writer.addHeaderAlias("orderCode", "订单编码");            writer.addHeaderAlias("addressName", "送达方名称");            writer.addHeaderAlias("amount", "订单金额");            writer.addHeaderAlias("orderStatusDesc", "订单状态");            writer.addHeaderAlias("createTime", "创建时间");            writer.addHeaderAlias("submitTime", "提交时间");            writer.addHeaderAlias("createTime", "创建时间");                //只保留别名的数据            writer.setOnlyAlias(true);            // 默认配置            writer.write(ordereList, true);            // 设置content—type            response.setContentType("application/vnd.openxmlfORMats-officedocument.spreadsheetml.sheet;charset:utf-8");            // 设置标题            String fileName = URLEncoder.encode("订单导出", "UTF-8");            //Content-disposition是MIME协议的扩展,MIME协议指示MIME用户代理如何显示附加的文件。            response.setHeader("Content-Disposition", "attachment;filename=" + fileName + ".xlsx");            ServletOutputStream outputStream = response.getOutputStream();            //将Writer刷新到OutPut            writer.flush(outputStream, true);            outputStream.close();            writer.close();          }

3.导出效果

4.Excel 表格导入 实现

    @PostMapping(path="/import")    public List importData(@RequestParam("file") MultipartFile file) throws IOException {        //字节输入流        InputStream inputStream = file.getInputStream();        //通过输入流创建ExcelReader 对象        ExcelReader reader = ExcelUtil.getReader(inputStream);        // 获取模板第一行第一列判断模板是否正确        if (!"*客户物料号".equals(reader.getOrCreateRow(0).getCell(0).toString())) {           throw new BusinessException("请按正确的模板导入!");        }        // 导入模板的列名要跟这个一致 不然字段是映射不上        reader.addHeaderAlias("*客户物料号","customerSkuCode");        reader.addHeaderAlias("*物料号","skuCode");        reader.addHeaderAlias("*数量","quantity");        reader.addHeaderAlias("*单位","unitDesc");        List list = reader.readAll(OrderItemResponse.class);        for (int i = 0; i < list.size(); i++) {          OrderItemResponse item = list.get(i);          // 设置模板行号 用于错误提示          item .setImportNo(i+2);          String msg = "";          // 校验必填          if (CollectionUtils.isNull(item.getSkuCode()){               msg = "客户物料号不能为空;";            }          if (CollectionUtils.isNull(item.getUnitDesc())) {               msg = msg + "数量单位不能为空;";           }          item.setErrorMsg(msg);         }                // 保存        service.BatchAdd(list);        // 把集合返回 用于前端展示成功行/失败行        return list;    }

 

来源地址:https://blog.csdn.net/lv_hang515888/article/details/131422906

--结束END--

本文标题: Java 使用hutool工具进行导出导入excel表格(代码很简单)

本文链接: https://www.lsjlt.com/news/416972.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作