成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

干掉EasyExcel!FastExcel初體驗

開發(fā) 前端
FastExcel 依然是原來的那個 EasyExcel,但又不完全是 EasyExcel,希望 FastExcel 越做越好。各位小伙伴們,一起體驗起來吧。

我們知道 EasyExcel 在作者從阿里離職之后就停止維護了,但在前兩周 EasyExcel 原作者推出了他的升級版框架 FastExcel。以下是 FastExcel 的上手實戰(zhàn)過程,帶大家一起提供新框架的魅力。

FastExcel 是由原 EasyExcel 作者創(chuàng)建的最新作品,作者在 2023 年從阿里離職后,隨著阿里宣布停止更新 EasyExcel,所以他就決定繼續(xù)維護和升級這個項目。在重新開始時,作者為它起名為 FastExcel,以突出這個框架在處理 Excel 文件時的高性能表現(xiàn),而不僅僅是簡單易用。

FastExcel 仍是免費的開源框架,它具備以下特點:

  • 完全兼容原 EasyExcel 的所有功能和特性,這使得用戶可以無縫過渡。
  • 從 EasyExcel 遷移到 FastExcel 只需簡單地更換包名和 Maven 依賴即可完成升級。
  • 在功能上,比 EasyExcel 提供更多創(chuàng)新和改進。
  • FastExcel 1.0.0 版本新增了讀取 Excel 指定行數(shù)和將 Excel 轉(zhuǎn)換為 PDF 的功能。

FastExcel 具體使用如下。

FastExcel 使用

1.添加依賴

<dependency>
  <groupId>cn.idev.excel</groupId>
  <artifactId>fastexcel</artifactId>
  <version>1.0.0</version> <!-- 請確保使用最新版本 -->
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
  <groupId>org.springframework.boot</groupId>
  <artifactId>spring-boot-starter</artifactId>
</dependency>

2.創(chuàng)建實體類和監(jiān)聽器

(1)創(chuàng)建實體類

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;
}

(2)創(chuàng)建事件監(jiān)聽器

FastExcel 是依靠事件監(jiān)聽器實現(xiàn) Excel 逐行讀取文件的,如果沒有這種逐行處理的機制和數(shù)據(jù)監(jiān)聽器,在處理大文件時可能會導致內(nèi)存溢出。而事件監(jiān)聽器使得數(shù)據(jù)可以邊讀取邊處理,例如,可以直接將數(shù)據(jù)寫入數(shù)據(jù)庫或者進行其他業(yè)務邏輯處理,避免了大量數(shù)據(jù)在內(nèi)存中的堆積。

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> {
    // 用于存儲讀取到的Excel數(shù)據(jù)對象列表
    private List<T> dataList = new ArrayList<>();
    @Override
    public void invoke(T t, AnalysisContext analysisContext) {
        // 每讀取一行數(shù)據(jù),就將其添加到dataList中
        dataList.add(t);
    }
    @Override
    public void doAfterAllAnalysed(AnalysisContext analysisContext) {
        // 當所有數(shù)據(jù)讀取完成后,可以在這里進行一些后續(xù)操作,如打印讀取到的數(shù)據(jù)數(shù)量
        System.out.println("讀取完成,共讀取了 " + dataList.size() + " 條數(shù)據(jù)");
    }
    // 提供一個方法用于獲取存儲數(shù)據(jù)的列表
    public List<T> getDataList() {
        return dataList;
    }
}

3.實現(xiàn)寫入和讀取功能

(1)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");
    // 寫入數(shù)據(jù)
    FastExcel.write(response.getOutputStream(), User.class)
    .sheet("模板")
    .doWrite(buildData());
}
// 創(chuàng)建測試數(shù)據(jù)
private List<User> buildData() {
    // 創(chuàng)建 User 測試數(shù)據(jù)
    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);
}

以上代碼執(zhí)行效果如下:

(2)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();
        // 得到讀取數(shù)據(jù)
        List<User> dataList = baseExcelListener.getDataList();
        System.out.println(dataList);
        return ResponseEntity.ok("文件上傳并處理成功!");
    } catch (IOException e) {
        return ResponseEntity.status(HttpStatus.INTERNAL_SERVER_ERROR).body("文件處理失敗!");
    }
}

以上代碼執(zhí)行效果如下:

EasyExcel 如何升級到FastExcel

1.修改依賴

將 EasyExcel 的依賴替換為 FastExcel 的依賴,如下:

<!-- easyexcel 依賴 -->
<dependency>
  <groupId>com.alibaba</groupId>
  <artifactId>easyexcel</artifactId>
  <version>xxxx</version>
</dependency>

依賴替換為:

<dependency>
  <groupId>cn.idev.excel</groupId>
  <artifactId>fastexcel</artifactId>
  <version>1.0.0</version>
</dependency>

2.修改代碼

將 EasyExcel 的包名替換為 FastExcel 的包名,如下:

// 將 easyexcel 的包名替換為 FastExcel 的包名
import com.alibaba.excel.**;

替換為:

import cn.idev.excel.**;

Excel轉(zhuǎn)換為PDF

FastExcel 支持將 Excel 文件轉(zhuǎn)換為 PDF 文件,F(xiàn)astExcel 將 Excel 轉(zhuǎn)為Pdf 底層依賴于 Apache POI 和 itext-pdf。受限于 itext-pdf 的許可證,請確保您的使用符合 itext-pdf 的許可證,后續(xù) FastExcel 將支持更多的 PDF 轉(zhuǎn)換功能替換 itext-pdf,實現(xiàn)代碼如下:

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

小結

FastExcel 依然是原來的那個 EasyExcel,但又不完全是 EasyExcel,希望 FastExcel 越做越好。各位小伙伴們,一起體驗起來吧。

責任編輯:姜華 來源: 磊哥和Java
相關推薦

2009-08-01 09:06:35

UbuntuOneLinux開源操作系統(tǒng)

2009-03-09 15:12:39

XenServer安裝

2023-07-15 08:01:38

2010-11-22 10:31:17

Sencha touc

2011-05-30 15:12:10

App Invento 初體驗

2011-08-02 10:26:59

iOS 多線程 線程

2011-11-01 10:30:36

Node.js

2013-06-08 10:15:29

Outlook 201Outlook 201

2011-09-15 15:03:10

2010-12-13 11:39:39

2025-03-18 07:30:41

2009-11-30 10:09:02

谷歌Chrome OS

2017-09-05 05:55:24

AWS ES集群大數(shù)據(jù)

2009-07-21 13:08:08

iBATIS DAO

2013-05-28 10:22:03

2023-07-17 08:34:03

RocketMQ消息初體驗

2011-09-05 10:20:21

Sencha ToucAPP

2025-04-10 07:30:43

2011-06-07 17:35:39

iphone 多線程

2010-05-13 21:03:42

Office 2010
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 狠狠操狠狠干 | 国产99久久精品一区二区永久免费 | 成人福利在线观看 | 亚洲一区二区不卡在线观看 | 国产一区二区精品自拍 | 欧美日韩在线成人 | 夜夜爽99久久国产综合精品女不卡 | 中文成人无字幕乱码精品 | 草久网| 麻豆久久久久久久久久 | 黄色片免费看视频 | 中文字幕在线观看视频网站 | 一区二区三区网站 | 欧美黄色片 | 九色porny自拍视频 | 国产精品一区在线观看 | 亚洲精品九九 | 日本午夜免费福利视频 | 日本久草视频 | 国产精品视频观看 | 精品一区二区三区电影 | 国产欧美精品一区二区色综合朱莉 | 精品国产乱码久久久久久影片 | 中文字幕一区二区三区精彩视频 | 国产xxx在线观看 | 91精品国产91久久久久游泳池 | 91传媒在线观看 | 国产日韩av一区二区 | 99精品免费视频 | 国产精品久久久久久久久久久新郎 | 国产精品中文字幕在线 | 国产精品久久久久久av公交车 | 国产三级| 91一区二区三区 | 一级二级三级黄色 | 免费黄色片在线观看 | 国产一区二区三区免费观看视频 | 一级黄a视频 | 亚洲www | 亚洲成人黄色 | 九九久久久|