我的编程空间,编程开发者的网络收藏夹
学习永远不晚

【EasyExcel】的一些用法

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

【EasyExcel】的一些用法

一、AnalysisEventListener监听类,可以用来解析Excel

用来进行监听,一方面,它可以处理空数据的检查,重复数据的检查等一些数据筛查工作。另一方面,也可以做数据的存储,如果在此做数据存储,那么数据的转换也是可以在这里完成的。

在该监听器中,通过重写AnalysisEventListener的方法来获得解析的数据、表头信息,以及解析完毕之后执行的操作信息。

public class ExcelListener extends AnalysisEventListener<UserData> {  public void invoke(UserData data, AnalysisContext analysisContext) {  System.out.println("****" + data); }  public void invokeHeadMap(Map<Integer, String> headMap, AnalysisContext context) {  System.out.println("表头" + headMap); }  public void doAfterAllAnalysed(AnalysisContext analysisContext) {  System.out.println("读取Excel完毕"); }}

调用:

public class EasyExcelReadDemo { public static void main(String[] args) {  // 实现excel写操作  //1.设置写入文件夹地址和excel文件名称  String fileName = "/Users/zzs/temp/excel/write.xlsx";  //调用easyExcel里面的方法实现写操作  //2个参数,第一个参数是文件名称,第二个参数是实体类  EasyExcel.read(fileName, UserData.class, new ExcelListener()).sheet().doRead(); }}

二、自定义转化器

通过自定义转换器,比如将1、0转换成男、女的实例:

public class SexConverter implements Converter<Integer> {    public Class<Integer> supportJavaTypeKey() {        return Integer.class;    }    public CellDataTypeEnum supportExcelTypeKey() {        return CellDataTypeEnum.STRING;    }    public Integer convertToJavaData(CellData cellData, ExcelContentProperty excelContentProperty, GlobalConfiguration globalConfiguration) throws Exception {        return "男".equals(cellData.getStringValue()) ? 1 : 0;    }    public CellData<String> convertToExcelData(Integer integer, ExcelContentProperty excelContentProperty, GlobalConfiguration globalConfiguration) throws Exception {        return new CellData<>(integer.equals(1) ? "男" : "女");    }}

使用:

@ExcelProperty(value="性别",converter = SexConverter.class)private Integer sex;

再次生成Excel,性别字段内容便显示为:男、女字样。

三、保留两位小数

比如体重需要保留两位小数,可通过@NumberFormat 注解实现:

@ExcelProperty(value = "体重KG")@NumberFormat("0.##") // 会以字符串形式生成单元格,要计算的列不推荐private BigDecimal weight;

另外一种方法是使用@ContentStyle注解:这样也能达到保留两位小数的效果。
当然,也可以使用实现Converter接口的方式实现(同性别实现)。

@ContentStyle(dataFormat = 2)private BigDecimal weight2;

四、排除指定Excel列

在很多场景下,Excel的列与实体类可能并不完全一致,这时就需要排除一些实体类的字段。
方式一:类上加注解 @ExcelIgnoreUnannotated,过滤属性没有@ExcelProperty注解的字段

@Data@ToString@AllArgsConstructor@NoArgsConstructor  // 一定要有无参构造方法@ExcelIgnoreUnannotatedpublic class UserData {    .....}

方式二:指定字段加@ExcelIgnore注解

@ExcelIgnore // 该字段不生成excelprivate String remark;

方式三:代码指定过滤字段,通过excludeColumnFiledNames方法,这种方法的好处是:同一Excel可以在调用方法时排除不同的数据列。

EasyExcel.write(fileName, UserData.class).sheet("学生信息表").excludeColumnFiledNames(Arrays.asList("remark")).doWrite(getData());

参考链接:https://jsnds.cn/2021/07/29/104400.html

来源地址:https://blog.csdn.net/m0_46459413/article/details/128659592

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

【EasyExcel】的一些用法

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

下载Word文档

猜你喜欢

Java中EasyExcel的使用方式

这篇文章主要介绍了Java中EasyExcel的使用方式,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的朋友可以参考一下
2022-11-13

python3一些用法

python3自定义算法排序 sorted(a1, key = functools.cmp_to_key(cmp))a1是待排序list,cmp为排序函数NumpyA = np.vstack([x,np.ones(len(x))]).T
2023-01-31

C# WindowsMediaPlayer 的一些用法实例

这篇文章介绍了C# WindowsMediaPlayer 的一些用法实例,有需要的朋友可以参考一下
2022-11-15

使用EasyExcel实现Excel的导入导出

文章目录 前言一、EasyExcel是什么?二、使用步骤1.导入依赖2.编写文件上传配置3.配置表头对应实体类4.监听器编写5.控制层6.前端代码 总结 前言 在真实的开发者场景中,经常会使用excel作为数据的载体,进行
2023-08-17

Android中WebView的一些简单用法

Android中WebView的一些简单用法 一直想写一个关于 WebView 控件的 一些简单运用,都没什么时间,这次也是挤出时间写的,里面的一些基础知识就等有时间再更新讲解一下,今天就先把项目出来做一些简单介绍,过多的内容可以看我的源码
2022-06-06

浅析UniApp的一些常用写法

UniApp是一个基于Vue.js的跨平台开发框架,可以开发iOS、Android、H5以及小程序等多个平台的应用程序。而在UniApp的开发中,有一些比较重要的写法需要我们注意和掌握,下面我们一起来详细了解一下。一、框架的结构UniApp的源代码主要由三部分组成:基础库、编译器和平台代码。其中,基础库由uni-core和uni-helpers两部分组成,负责提供UniApp必
2023-05-14

浅析C++中static的一些用法

static是静止的,静态的意思,那它有什么用呢,今天通过实例代码讲解下C++中static的一些用法,感兴趣的朋友跟随小编一起看看吧
2022-12-08

分享一些RxJava的特殊用法

这篇文章给大家介绍分享一些RxJava的特殊用法,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。一、按钮绑定通过 RxView 可以对 view 进行快速的 clicks 绑定RxView.clicks(button).
2023-05-31

React-Native中一些常用组件的用法详解(一)

前言本文为大家介绍一下React-Native中一些常用的组件,由于对ES6的语法并没有完全掌握,这里暂时用ES5和ES6混用的语法。View组件View是一个支持Flexbox布局、样式、一些触摸处理、和一些无障碍功能的容器,并且它可以放
2023-05-31

聊聊HTML的一些常用写法

抱歉,我刚才的回答有误,现回答应该为HTML写法:HTML是一种标记语言,用于创建网页和其他网络应用程序。下面介绍HTML的一些常用写法。1. 基本语法结构<!doctype html><html><head><meta charset="utf-8"><title>页面标题</title></head><body>页面内容</body></html>以上就
2023-05-14

python3-字典的一些常用方法

# Auther: Aaron Fan#在dict_dict字典中包含字典那个脚本里介绍了这个方法的用法:'''print(av_catalog.setdefault('大陆',{'www.baidu.com':[1,2]}))  #如果a
2023-01-31

java实现excel的导出之使用easyExcel

前言 在我们的项目需求中,经常会遇到导出的需求,其中excel的导出最为常见。生成Excel比较有名的框架有Apache poi,jxl等,但他们都存在一个严重的问题就是非常的耗内存,如果你的系统并发量不大的话可能还行,但是一旦并发上来后一
2023-08-18

阿里的Easyexcel读取Excel文件的方法(最新版本)

这篇文章主要介绍了阿里的Easyexcel读取Excel文件(最新版本)的方法,本文通过示例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
2022-12-16

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录