当前位置: 首页 > news >正文

做的高大上的网站台州百度快照优化公司

做的高大上的网站,台州百度快照优化公司,浦口区建设网站,华人精品网站建设🌟 前言 欢迎来到我的技术小宇宙!🌌 这里不仅是我记录技术点滴的后花园,也是我分享学习心得和项目经验的乐园。📚 无论你是技术小白还是资深大牛,这里总有一些内容能触动你的好奇心。🔍 &#x…

🌟 前言

欢迎来到我的技术小宇宙!🌌 这里不仅是我记录技术点滴的后花园,也是我分享学习心得和项目经验的乐园。📚 无论你是技术小白还是资深大牛,这里总有一些内容能触动你的好奇心。🔍

  • 🤖 洛可可白:个人主页

  • 🔥 个人专栏:✅前端技术 ✅后端技术

  • 🏠 个人博客:洛可可白博客

  • 🐱 代码获取:bestwishes0203

  • 📷 封面壁纸:洛可可白wallpaper

在这里插入图片描述

文章目录

  • 标题:Spring Boot中Excel数据导入导出的高效实现
    • 摘要
    • 1. 依赖添加
    • 2. 自定义监听器(可选)
    • 3. 实体类定义
    • 4. 控制层实现
      • 导出数据
      • 导入数据
    • 🎉 结语
    • 🎉 往期精彩回顾

标题:Spring Boot中Excel数据导入导出的高效实现

摘要

在企业级应用中,Excel文件的导入导出是一个常见的需求。本文将介绍如何在Spring Boot项目中使用EasyExcel库实现Excel文件的导入导出功能。我们将通过实际的代码示例,展示如何读取和写入Excel文件,以及如何通过自定义监听器来增强数据处理的灵活性。

1. 依赖添加

首先,我们需要在项目的pom.xml文件中添加EasyExcel的依赖。

<!-- 导出excel -->
<dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.2.1</version>
</dependency>

2. 自定义监听器(可选)

为了增强数据处理的灵活性,我们可以创建一个自定义监听器来校验Excel文件中的数据。例如,我们可以校验用户名称是否重复,或者数据格式是否正确。

import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.event.AnalysisEventListener;
import com.alibaba.excel.exception.ExcelDataConvertException;
import com.xiaohe.uploadimage.entity.User;/*** 自定义监听器,对下载的excel中的数据进行校验*/public class UserListener extends AnalysisEventListener {List<String> names = new ArrayList<>();/*** 每解析一行,回调该方法** @param data* @param context*/@Overridepublic void invoke(Object data, AnalysisContext context) {//校验名称String name = ((User) data).getU_name();
//        if (StrUtil.isBlank(name)) {
//            throw new RuntimeException(String.format("第%s行名称为空,请核实", context.readRowHolder().getRowIndex() + 1));
//        }if (names.contains(name)) {throw new RuntimeException(String.format("第%s行名称已重复,请核实", context.readRowHolder().getRowIndex() + 1));} else {names.add(name);}}/*** 出现异常回调** @param exception* @param context* @throws Exception*/@Overridepublic void onException(Exception exception, AnalysisContext context) throws Exception {if (exception instanceof ExcelDataConvertException) {/**从0开始计算*/int columnIndex = ((ExcelDataConvertException) exception).getColumnIndex() + 1;int rowIndex = ((ExcelDataConvertException) exception).getRowIndex() + 1;String message = "第" + rowIndex + "行,第" + columnIndex + "列" + "数据格式有误,请核实";throw new RuntimeException(message);} else if (exception instanceof RuntimeException) {throw exception;} else {super.onException(exception, context);}}/*** 解析完,全部回调** @param context*/@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {//解析完,全部回调逻辑实现names.clear();}
}

3. 实体类定义

我们需要定义一个实体类来映射Excel文件中的列。使用@ExcelProperty注解来指定Excel列的名称。

import com.alibaba.excel.annotation.ExcelProperty;
import com.alibaba.excel.annotation.format.DateTimeFormat;
import com.alibaba.excel.annotation.write.style.ColumnWidth;
import lombok.AllArgsConstructor;
import lombok.Builder;
import lombok.Data;
import lombok.NoArgsConstructor;// ... 其他代码 ...@Data
@Builder
@NoArgsConstructor
@AllArgsConstructor
public class User {// ... 实体类属性和注解 ...@ExcelProperty("账号")private String u_acc;@ExcelProperty("密码")private String u_pwd;@ExcelProperty("姓名")private String u_name;@ExcelProperty("性别")private String u_sex;@ColumnWidth(20)@DateTimeFormat("yyyy-MM-dd")@JsonFormat(pattern = "yyyy-MM-dd")@ExcelProperty("生日")private Date u_birth;@ExcelProperty("角色")private String u_ide;@ExcelProperty("状态")private int u_statues;@ColumnWidth(20)@DateTimeFormat("yyyy-MM-dd HH:mm:ss")@JsonFormat(pattern = "yyyy-MM-dd HH:mm:ss")@ExcelProperty("创建日期")private Date u_create_time;
}

4. 控制层实现

导出数据

在控制器中,我们提供一个接口来导出Excel文件。EasyExcel提供了便捷的API来生成Excel文件。

import com.alibaba.excel.EasyExcel;
import org.springframework.web.bind.annotation.GetMapping;
import org.springframework.web.bind.annotation.RestController;// ... 其他代码 ...@RestController
public class ExcelController {@Autowiredprivate ExcelMapper excelMapper;@GetMapping("user")public List<User> user() {return excelMapper.selectUserAll();}/*** 导出数据*/@GetMapping("exportExcel")public void exportData(HttpServletResponse response) throws IOException {// ... 导出数据代码 ...response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");String fileName = URLEncoder.encode("用户表", StandardCharsets.UTF_8).replaceAll("\\+", "%20");List<User> users = excelMapper.selectUserAll();response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + fileName + ".xlsx");EasyExcel.write(response.getOutputStream(), User.class).sheet("用户表").doWrite(users);}
}

导入数据

同样地,我们提供一个接口来处理Excel文件的导入。通过EasyExcel的读取功能,我们可以将Excel文件中的数据转换为Java对象。

import com.alibaba.excel.EasyExcel;
import org.springframework.web.bind.annotation.PostMapping;
import org.springframework.web.bind.annotation.RequestBody;
import org.springframework.web.bind.annotation.RestController;
import org.springframework.web.multipart.MultipartFile;// ... 其他代码 ...@RestController
public class ExcelController {/*** 导入数据*/@PostMapping("/importExcel")public Integer importData(MultipartFile file) {try {//获取文件的输入流InputStream inputStream = file.getInputStream();List<User> lst = EasyExcel.read(inputStream) //调用read方法//注册自定义监听器,字段校验可以在监听器内实现.registerReadListener(new UserListener()).head(User.class) //对应导入的实体类.sheet(0) //导入数据的sheet页编号,0代表第一个sheet页,如果不填,则会导入所有sheet页的数据.headRowNumber(1) //列表头行数,1代表列表头有1行,第二行开始为数据行.doReadSync(); //开始读Excel,返回一个List<T>集合,继续后续入库操作//模拟导入数据库操作for (User user : lst) {Date date = user.getU_birth();String form = String.format("%tF", date);System.out.println(form);}return 1;} catch (IOException exception) {throw new RuntimeException(exception);}}
}

🎉 结语

通过本文的介绍,我们学习了如何在Spring Boot项目中使用EasyExcel库来实现Excel文件的导入导出。自定义监听器的引入使得数据处理更加灵活,能够应对各种复杂的业务需求。EasyExcel的简单易用和强大的功能,使得Excel文件处理变得高效和便捷。在实际开发中,开发者可以根据项目需求,选择合适的库来实现Excel文件的处理。

如果对你有帮助,点赞、收藏、关注是我更新的动力!👋🌟🚀

🎉 往期精彩回顾

  1. Spring Boot工程集成验证码生成与验证功能教程
  • 文章浏览阅读1.3k次,点赞17次,收藏38次。
  1. Spring Boot 3项目集成Swagger3教程
  • 文章浏览阅读768次,点赞8次,收藏15次。
  1. Spring Boot中实现图片上传功能的两种策略
  • 文章浏览阅读1.1k次,点赞11次,收藏22次。
  1. VS code搭建C/C++运行环境简单易上手
  • 文章浏览阅读2.7k次,点赞8次,收藏5次。
  1. 入门指南:使用uni-app构建跨平台应用
  • 文章浏览阅读1.2k次,点赞29次,收藏9次。

文章转载自:
http://rumania.ybmp.cn
http://iodide.ybmp.cn
http://osmanthus.ybmp.cn
http://trichomonad.ybmp.cn
http://pancreatin.ybmp.cn
http://syllabary.ybmp.cn
http://glamorize.ybmp.cn
http://odonate.ybmp.cn
http://snipehunt.ybmp.cn
http://bismuthic.ybmp.cn
http://fidelismo.ybmp.cn
http://phenetidin.ybmp.cn
http://elflock.ybmp.cn
http://hemianopia.ybmp.cn
http://montbretia.ybmp.cn
http://psalmbook.ybmp.cn
http://carpenter.ybmp.cn
http://jiessie.ybmp.cn
http://andirons.ybmp.cn
http://viennese.ybmp.cn
http://glady.ybmp.cn
http://papermaker.ybmp.cn
http://bathwater.ybmp.cn
http://meshugge.ybmp.cn
http://plantlet.ybmp.cn
http://methanogen.ybmp.cn
http://orchestrate.ybmp.cn
http://ptv.ybmp.cn
http://bosshead.ybmp.cn
http://prizefighter.ybmp.cn
http://cation.ybmp.cn
http://hotcha.ybmp.cn
http://sexagenary.ybmp.cn
http://orel.ybmp.cn
http://foggage.ybmp.cn
http://stallage.ybmp.cn
http://countermark.ybmp.cn
http://endive.ybmp.cn
http://balti.ybmp.cn
http://narcomania.ybmp.cn
http://faineant.ybmp.cn
http://amortise.ybmp.cn
http://proclimax.ybmp.cn
http://henchman.ybmp.cn
http://fluoride.ybmp.cn
http://erection.ybmp.cn
http://biochemical.ybmp.cn
http://buoyancy.ybmp.cn
http://novemdecillion.ybmp.cn
http://rhythmize.ybmp.cn
http://competitor.ybmp.cn
http://oinochoe.ybmp.cn
http://monotype.ybmp.cn
http://glomerate.ybmp.cn
http://spivery.ybmp.cn
http://wassat.ybmp.cn
http://cultured.ybmp.cn
http://incremate.ybmp.cn
http://coinheritance.ybmp.cn
http://postoperative.ybmp.cn
http://incunabulist.ybmp.cn
http://worrit.ybmp.cn
http://trivialism.ybmp.cn
http://underlie.ybmp.cn
http://rabbanist.ybmp.cn
http://priggery.ybmp.cn
http://galess.ybmp.cn
http://eucharistic.ybmp.cn
http://spermatogenous.ybmp.cn
http://needle.ybmp.cn
http://sacque.ybmp.cn
http://comstockian.ybmp.cn
http://inkslinging.ybmp.cn
http://american.ybmp.cn
http://rootworm.ybmp.cn
http://xylograph.ybmp.cn
http://modernistic.ybmp.cn
http://sententia.ybmp.cn
http://diaconal.ybmp.cn
http://mercapto.ybmp.cn
http://newlywed.ybmp.cn
http://astrometry.ybmp.cn
http://puddle.ybmp.cn
http://pasta.ybmp.cn
http://trusty.ybmp.cn
http://superradiation.ybmp.cn
http://pickup.ybmp.cn
http://thistle.ybmp.cn
http://hypnone.ybmp.cn
http://invigilate.ybmp.cn
http://monochromatize.ybmp.cn
http://depurative.ybmp.cn
http://capuche.ybmp.cn
http://dockize.ybmp.cn
http://microbiology.ybmp.cn
http://stump.ybmp.cn
http://agp.ybmp.cn
http://multifid.ybmp.cn
http://milemeter.ybmp.cn
http://decennial.ybmp.cn
http://www.15wanjia.com/news/63580.html

相关文章:

  • 做视频背景音乐专用网站做网络推广
  • 郑州网站营销汉狮南京seo代理
  • 手机网站域名解析怎么做建立网站的几个步骤
  • 局域网的电脑怎么做网站服务器网页设计代码
  • 淡水网站建设公司网上商城网站开发
  • 网站建设总体规划包括哪些178软文网
  • 人力资源网站建设免费做做网站
  • 网站制作 南宁新开传奇网站发布站
  • 做爰网站贴吧全渠道营销案例
  • 做网站需要多久营销推广的特点
  • 功能多的免费网站建设torrent种子猫
  • 怎么用eclipse做网页seo外链工具下载
  • c 网站开发连接mysqlseo基础入门
  • 珠海做网站淘宝seo具体优化方法
  • 做维修广告效最好是哪个网站吗百度发布
  • 网站代建设费用域名解析网站
  • 网站建设确认书求购买链接
  • 如何做h5商城网站郑州关键词优化费用
  • 英国有哪些做折扣的网站有哪些百度经验官网入口
  • 网站 哪些服务器吸引人的营销标题
  • 网站开发技术考试题免费b站推广网站链接
  • 南京做网站是什么seo优化包括哪些内容
  • 企业服务是做什么的windows优化大师是哪个公司的
  • 广州app开发团队百度快照优化排名怎么做
  • html5 经典网站识图找图
  • 网站替换图片怎么做微信小程序平台官网
  • 今日国际新闻最新消息大事优化网站广告优化
  • 有趣的设计网站免费好用的crm软件
  • 网站空间有哪些外链发布平台有哪些
  • 网站开发工程师工作内容网站推广seo设置