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

美肤宝网站建设笔记本做系统哪个网站好

美肤宝网站建设,笔记本做系统哪个网站好,郑州百度推广公司地址,天猫店铺一个多少钱目录 简介 FastExcel的特点 FastExcel使用方法详解 创建实体类和监听器 实现写入和读取功能 Excel转换为PDF 小结 FastExcel与EasyExcel的区别 结论 简介 FastExcel是由原EasyExcel作者在阿里巴巴宣布停止维护EasyExcel之后推出的升级版框架。它继承了EasyExcel的所有…

目录

简介

FastExcel的特点

FastExcel使用方法详解

创建实体类和监听器

实现写入和读取功能

Excel转换为PDF

小结

FastExcel与EasyExcel的区别

结论

简介

FastExcel是由原EasyExcel作者在阿里巴巴宣布停止维护EasyExcel之后推出的升级版框架。它继承了EasyExcel的所有优点,并且在性能和功能上进行了显著的提升和创新。

FastExcel的特点

  • 高性能读写: FastExcel专注于性能优化,能够高效处理大规模的Excel数据,显著降低内存占用。
  • 简单易用: 提供了简洁直观的API,使得开发者可以轻松集成到项目中,无论是简单的Excel操作还是复杂的数据处理都能快速上手。
  • 流式操作: 支持流式读取,将一次性加载大量数据的问题降到最低,特别适合处理数十万甚至上百万行的数据。
  • 完全兼容: 完全兼容原EasyExcel的所有功能和特性,用户可以无缝过渡。
  • 持续更新: FastExcel会持续更新,修复bug,优化性能,增加新功能。

FastExcel使用方法详解

创建实体类和监听器
  • 创建实体类

在使用FastExcel进行Excel文件的读写操作之前,需要定义一个实体类,该类中的每个属性对应Excel中的一列。使用@ExcelProperty注解来指定列名。

import cn.idev.excel.annotation.ExcelProperty;
import lombok.Getter;
import lombok.Setter;
import lombok.ToString;@Setter
@Getter
@ToString
public class User {@ExcelProperty("编号")private Integer id;@ExcelProperty("名字")private String name;@ExcelProperty("年龄")private Integer age;
}
  • 创建事件监听器

FastExcel通过事件监听器实现Excel文件的逐行读取,这对于处理大文件尤为重要,因为它可以避免内存溢出的问题。下面是一个事件监听器的示例,它在读取每行数据时将数据添加到列表中,并在所有数据读取完成后执行一些操作。

import cn.idev.excel.context.AnalysisContext;
import cn.idev.excel.event.AnalysisEventListener;
import java.util.ArrayList;
import java.util.List;public class BaseExcelListener<T> extends AnalysisEventListener<T> {private List<T> dataList = new ArrayList<>();@Overridepublic void invoke(T t, AnalysisContext analysisContext) {dataList.add(t);}@Overridepublic void doAfterAllAnalysed(AnalysisContext analysisContext) {System.out.println("读取完成,共读取了 " + dataList.size() + " 条数据");}public List<T> getDataList() {return dataList;}
}
实现写入和读取功能
  • Excel写入功能

以下是使用FastExcel进行Excel写入的示例代码。首先,创建测试数据,然后通过FastExcel.write方法将数据写入到Excel文件中。

// Excel写入功能
@GetMapping("/download")
public void download(HttpServletResponse response) throws IOException {response.setContentType("application/vnd.openxmlformats-officedocument.spreadsheetml.sheet");response.setCharacterEncoding("utf-8");String fileName = URLEncoder.encode("test", "UTF-8");response.setHeader("Content-disposition","attachment;filename*=utf-8''" + fileName + ".xlsx");// 写入数据FastExcel.write(response.getOutputStream(), User.class).sheet("模板").doWrite(buildData());
}// 创建测试数据
private List<User> buildData() {User user1 = new User();user1.setId(1);user1.setName("张三");user1.setAge(18);User user2 = new User();user2.setId(2);user2.setName("李四");user2.setAge(19);return List.of(user1, user2);
}
  • Excel读取功能

以下是使用FastExcel进行Excel读取的示例代码。通过FastExcel.read方法读取Excel文件,并使用之前创建的监听器来处理读取到的数据。

// Excel读取功能
@PostMapping("/upload")
public ResponseEntity<String> upload(@RequestParam("file") MultipartFile file) {if (file.isEmpty()) {return ResponseEntity.badRequest().body("请选择一个文件上传!");}try {BaseExcelListener<User> baseExcelListener = new BaseExcelListener<>();FastExcel.read(file.getInputStream(), User.class, baseExcelListener).sheet().doRead();List<User> dataList = baseExcelListener.getDataList();System.out.println(dataList);return ResponseEntity.ok("文件上传并处理成功!");} catch (IOException e) {return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("文件处理失败!");}
}
Excel转换为PDF

FastExcel还支持将Excel文件转换为PDF文件,这一功能底层依赖于Apache POI和itext-pdf。请注意,使用itext-pdf时需要确保符合其许可证要求。

FastExcel.convertToPdf(new File("excelFile"),new File("pdfFile"),null,null);
小结

FastExcel作为一个高效且易于使用的Excel处理工具,不仅继承了EasyExcel的所有优点,还在此基础上进行了性能和功能的增强。

通过上述示例,我们可以看到FastExcel如何简化Excel文件的读写操作,以及如何通过事件监听器实现流式处理,从而有效管理内存使用。无论是企业数据导入导出还是个人项目开发,FastExcel都能提供强大的支持。

FastExcel与EasyExcel的区别

  • 性能提升: FastExcel在性能上比EasyExcel更好,更稳定。
  • API一致性: FastExcel与EasyExcel的API完全一致,可以无缝切换。
  • 功能增加: FastExcel 1.0.0版本新增了读取Excel指定行数和将Excel转换为PDF的功能。

结论

FastExcel作为一个轻量级但功能强大的Java库,专为需要高性能和低内存占用的Excel文件处理而设计。如果您的项目需要处理大规模的Excel数据,FastExcel无疑是一个值得考虑的选择。其流式处理和灵活的API使其成为处理Excel文件的理想工具。

觉得有用的话可以点点赞 (*/ω\*),支持一下。

如果愿意的话关注一下。会对你有更多的帮助。

每天都会不定时更新哦 >人< 。

http://www.yayakq.cn/news/64207/

相关文章:

  • dw网站建设框架大小设定如何制作网站的app
  • 天门网站设计成都建设企业网站
  • 广东建设注册中心网站株洲最新消息
  • 南通优普网站建设团队合肥seo按天扣费
  • 住房和城乡建设网站 上海用一个矿泉水瓶子做手工
  • 网站建设与运营的预算方案模板wordpress所有数据迁移
  • 涉县住房和城乡规划建设局网站创建信息平台的方法
  • 餐饮网站建设背景阿里巴巴国际站运营培训
  • 网站建设的步骤图片过程人才招聘网最新招聘2022
  • php门户网站模板下载如何开一个网站
  • wordpress整站密码无锡网站建设推广服务
  • 佛山专业做网站公司有哪些一个网站seo做哪些工作
  • 沈阳个人网站建设代理品牌一般纳税人企业所得税怎么征收
  • 影响网站排名的因素 权重梅州建站方法
  • 网站建设多语种自动翻译插件中国住建网的官网
  • 同人那个小说网站做的最好小程序开发公司排行
  • 红色网站 后台做网站效果
  • 网站都需要什么类别北京市建设教育协会网站查询系统
  • 专门做美食的网站域名转接的流程
  • 用vscode做网站哪个网站做国际生意
  • 网站色彩策划长春seo优化
  • 重庆营销型网站开发公司亚马逊没有网站怎么做seo
  • 舜江建设集团官方网站金坛市住房和城乡建设局网站
  • wordpress可以建网站吗外贸响应式网站
  • 福建省建设干部培训中心网站win7可以做网站吗
  • 主流软件开发平台百度seo算法
  • 建设一个淘宝客网站营销网站建设维护
  • 青岛网站建设官网专业网站建设顾问
  • 营销型网站的类型有哪些做网站要注意哪些
  • wordpress 获取主题名称seo网站排名优化公司