POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能

本文主要是介绍POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

《POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能》ApachePOI是一个流行的Java库,用于处理MicrosoftOffice格式文件,提供丰富API来创建、读取和修改O...

前言:

Apache POI

        是一个流行的 Java 库,用于处理 Microsoft Office 格式文件,提供丰富 API 来创建、读取和修改 Office 文档。

1.官网:Apache POI™ - the Java API for Microsoft Documents

2.优点:功能强大,可处理复杂 Excel 文件;稳定性高,受广泛支持与维护;灵活性好,能满足定制需求。

3.缺点:学习曲线陡,对初学者成本高;处理大量数据时性能受影响。

EasyPoi

        主打功能简单易用,通过简单注解和模板语言就能实现 Excel 导出、导入、Word 模板导出等功能。

1.官网:https://gitee.com/lemur/easypoi

2.优点:API 接口简洁,操作便捷;功能丰富,支持多种操作;基于 Apache POI 和 JexcelApi,易于扩展;文档详细,便于学习使用。

3.缺点:与 Apache POI 相比,高级功能有限;因封装层存在,处理大量数据有性能损耗。

EasyExcel

        是阿里巴巴基于 Apache POI 封装的开源框架,专注 Excel 文件读写。

1.官网:EasyExcel官方文档 - 基于Java的Excel处理工具 | Easy Excel 官网

2.优点:API 简洁,使用方便;处理大量数据时性能高;支持注解配置导入导出规则,简化开发。

3.缺点:相比 Apache POI,功能简单,无法满足复杂需求;定制化能力不如 Apache POI 灵活。

一、EasyExcel

       EasyExcel 是阿里巴巴开源的一个基于 Java 的简单、省内存的读写 Excel 工具。在处理大文件时,它能极大地减少内存占用,并且使用起来相对简单。

1.1、核心特性

内存占用少:采用逐行读取和写入的方式,无需将整个 Excel 文件加载到内存中,避免了内存溢出问题,适合处理大数据量的 Excel 文件。例如在处理包含数万条数据的 Excel 文件时,传统方式可能会导致内存不足,而 EasyExcel 可以轻松应对。

API 简单:提供了简洁的 API,通过注解就能完成 Excel 数据的读写映射,降低了开发成本和学习成本。开发人员只需简单配置注解,就能实现数据与 Excel 单元格的映射。

功能丰富:支持 Excel 的导入导出、数据校验、自定义格式等功能,还能处理复杂表头和多级表头。

性能高效:在读写性能上表现出色,能够快速处理大量数据,提高程序的执行效率。

1.2、常用注解

@ExcelProperty:用于指定 Excel 列的表头名称、顺序等信息,是最常用的注解。可以通过 value 属性指定表头名称,通过 index 属性指定列的索引。

@DateTimeFormat:用于格式化日期类型的数据。例如 @DateTimeFormat("yyyy-MM-dd") 可以将日期格式化为指定的字符串。

@NumberFormat:用于格式化数字类型的数据。例如 @NumberFormat("#.##%") 可以将数字格式化为百分比形式。

1.3、使用步骤

1.3.1、引入依赖

<dependency>
    <groupId>com.alibaba</groupId>
    <artifactId>easyexcel</artifactId>
    <version>3.3.2</version>
</dependency>

1.3.2、创建实体对象

@Data
public class SysUserData {
    @ExcelProperty("用户姓名")
    private String uname;
    @ExcelProperty("真实姓名")
    private String iphone;
    @ExcelProperty("用户名")
    private String realName;
    @ExcelProperty("密码")
    private String ipassword;
    @ExcelProperty("登陆ip")
    private String lastloginip;
    @ExcelProperty("登录时间")
    private String lastlogintime;
    @ExcelProperty("登陆次数")
    private String logintimes;
    @ExcelProperty("账号状态")
    private int state;
}

1.3.3、导入

/**
     * easyExcl
     * 导入excel
     * @return
     */
    @RequestMapping(value = "/easyExcelImport")
    public List<SysUser> easyExcelImport() {
        List<SysUser> uList = null;
        try {
            uList = new ArrayList<>();
            String filePath = "/Users/admin/Desktop/user.xlsx";
            List<SysUserData> userList = EasyExcel.read(filePath).head(SysUserData.class).sheet().doReadSync();
            for (SysUserData user : userList) {
                SysUser sysUser = new SysUser();
                sysUser.setUname(user.getUname());
                sysUser.setRealChina编程Name(user.getRealName());
         www.chinasem.cn       sysUser.setIphone(user.getIphone());
                sysUser.setIpassword(user.getIpassword());
                sysUser.setLastloginip(user.getLastloginip());
     www.chinasem.cn           sysUser.setLastlogintime(DateUtils.DateTimeToTimestamp(String.valueOf(user.getLastlogintime())));
                sysUser.setLogintimes(user.getLogintimes());
                sysUser.setState(user.getState());
                userService.addUser(sysUser);
                uList.add(sysUser);
            }
        } catch (Exception e) {
            e.printStackTrace();
        }
        return uList;
    }

1.3.4、导出

 /**
     * easyexcel
     * 导出
     * @param response
   ynyYqSlH  * @throws IOException
     */
    @RequestMapping(value = "/easyExcelWrite")
    public void easyExcelWrite(HttpServletResponse response) throws IOException {
        response.setCharacterEncoding("utf-8");
        long timestamp = System.currentTimeMillis() / 1000;
        String fileName = "用户信息_" + timestamp + ".xlsx";
        String encodedFileName = URLEncoder.encode(fileName, "UTF-8");
        response.setHeader("Content-disposition", "attachment;filename*=utf-8''" + encodedFileName);
        List<SysUserData> dataList = new ArrayList<SysUserData>();
        // 数据
        List<SysUser> userList = userService.userList();
        for (SysUser user : userList) {
            SysUserData SysUserData = new SysUserData();
            SysUserData.setUname(user.getUname());
            SysUserData.setRealName(user.getRealName());
            SysUserData.setIphone(user.getIphone());
            SysUserData.setIpassword(user.getIpassword());
            SysUserData.setLastloginip(user.getLastloginip());
            SysUserData.setLastlogintime(DateUtils.TimestampToDateTime(user.getLastlogintime()));
            SysUserData.setLogintimes(user.getLogintimes());
            SysUserData.setState(user.getState());
            dataList.add(SysUserData);
        }
        HorizontalCellStyleStrategy horizontalCellStyleStrategy = new HorizontalCellStyleStrategy(StyleUtils.getHeadStyle(), StyleUtils.getContentStyle(python));
        try (
        ExcelWriter excelWriter = EasyExcel.write(response.getOutputStream(), SysUserData.class)
                .registerWriteHandler(new CellWriteWidthConfig()) // 自适应列宽
                .registerWriteHandler(new CellWriteHeightconfig()) // 自适应行高
                .registerWriteHandler(horizontalCellStyleStrategy)
                .build()) {
            excelWriter.write(dataList, EasyExcel.writerSheet("用户信息").build());
        }catch (IOException e) {
            throw new RuntimeException(e);
        }
    }

通过以上内容便可轻轻松松使用EasyExcel.是不是超级简单.有任何问题欢迎留言哦!!!

到此这篇关于POI从入门到实战轻松完成EasyExcel使用,完成Excel导入导出.的文章就介绍到这了,更多相关POI EasyExcel使用内容请搜索China编程(www.chinasem.cn)以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程China编程(www.chinasem.cn)!

这篇关于POI从入门到实战轻松完成EasyExcel使用及Excel导入导出功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1154530

相关文章

Java 如何创建和使用ExecutorService

《Java如何创建和使用ExecutorService》ExecutorService是Java中用来管理和执行多线程任务的一种高级工具,可以有效地管理线程的生命周期和任务的执行过程,特别是在需要处... 目录一、什么是ExecutorService?二、ExecutorService的核心功能三、如何创建

使用FileChannel实现文件的复制和移动方式

《使用FileChannel实现文件的复制和移动方式》:本文主要介绍使用FileChannel实现文件的复制和移动方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录使用 FileChannel 实现文件复制代码解释使用 FileChannel 实现文件移动代码解释

Java中的getBytes()方法使用详解

《Java中的getBytes()方法使用详解》:本文主要介绍Java中getBytes()方法使用的相关资料,getBytes()方法有多个重载形式,可以根据需要指定字符集来进行转换,文中通过代... 目录前言一、常见重载形式二、示例代码三、getBytes(Charset charset)和getByt

Java使用Stream流的Lambda语法进行List转Map的操作方式

《Java使用Stream流的Lambda语法进行List转Map的操作方式》:本文主要介绍Java使用Stream流的Lambda语法进行List转Map的操作方式,具有很好的参考价值,希望对大... 目录背景Stream流的Lambda语法应用实例1、定义要操作的UserDto2、ListChina编程转成M

Spring框架中@Lazy延迟加载原理和使用详解

《Spring框架中@Lazy延迟加载原理和使用详解》:本文主要介绍Spring框架中@Lazy延迟加载原理和使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、@Lazy延迟加载原理1.延迟加载原理1.1 @Lazy三种配置方法1.2 @Component

使用easy connect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题

《使用easyconnect之后,maven无法使用,原来需要配置-Djava.net.preferIPv4Stack=true问题》:本文主要介绍使用easyconnect之后,maven无法... 目录使用easGWowCy connect之后,maven无法使用,原来需要配置-DJava.net.pr

使用Java编写一个字符脱敏工具类

《使用Java编写一个字符脱敏工具类》这篇文章主要为大家详细介绍了如何使用Java编写一个字符脱敏工具类,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录1、字符脱敏工具类2、测试工具类3、测试结果1、字符脱敏工具类import lombok.extern.slf4j.Slf4j

pandas DataFrame keys的使用小结

《pandasDataFramekeys的使用小结》pandas.DataFrame.keys()方法返回DataFrame的列名,类似于字典的键,本文主要介绍了pandasDataFrameke... 目录Pandas2.2 DataFrameIndexing, iterationpandas.DataF

使用Python和PaddleOCR实现图文识别的代码和步骤

《使用Python和PaddleOCR实现图文识别的代码和步骤》在当今数字化时代,图文识别技术的应用越来越广泛,如文档数字化、信息提取等,PaddleOCR是百度开源的一款强大的OCR工具包,它集成了... 目录一、引言二、环境准备2.1 安装 python2.2 安装 PaddlePaddle2.3 安装

嵌入式Linux之使用设备树驱动GPIO的实现方式

《嵌入式Linux之使用设备树驱动GPIO的实现方式》:本文主要介绍嵌入式Linux之使用设备树驱动GPIO的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录一、设备树配置1.1 添加 pinctrl 节点1.2 添加 LED 设备节点二、编写驱动程序2.1