EasyExcel简介

Java解析、生成Excel比较有名的框架有Apache poi、jxl。但他们都存在一个严重的问题就是非常的耗内存,poi有一套SAX模式的API可以一定程度的解决一些内存溢出的问题,但POI还是有一些缺陷,比如07版Excel解压缩以及解压后存储都是在内存中完成的,内存消耗依然很大。easyexcel重写了poi对07版Excel的解析,能够原本一个3M的excel用POI sax依然需要100M左右内存降低到几M,并且再大的excel不会出现内存溢出,03版依赖POI的sax模式。在上层做了模型转换的封装,让使用者更加简单方便

动态表头

查看easyexcel支持导出表头设置方法,表头导出支持Class,List> 类型。由于是动态表头 Class 类型不易封装,List> 类型更加适合。

动态列

查看easyexcel支持数据导出格式,List.此处的List 是否支持List>格式

跟踪代码,查找List 处理流程。经过跟踪,在创建excel之前,对类型进行了判断处理。

跟踪代码利器SequenceDiagram

怎样去跟踪代码?提供一个idea的插件SequenceDiagram,通过插件可以生成代码的调用流程,跟踪代码会更加方便。

以下是 easyexcel doWrite() 方法处理的时序图。

实现动态表头,动态列导出

表头。创建head方法,返回值类型List>

动态列

private List> data(){ List> list = new ArrayList>(); List data0 = new ArrayList(); data0.add("data1"); data0.add("data2"); data0.add("data3"); list.add(data0); return list;}
EasyExcel.write("动态表头xls").head(head()).sheet("模板").doWrite(data());

效果

总结

使用easyexcel 导出动态表头,列数据。只需构造符合List> 格式数据即可。这与POI 直接使用起来更加的简单。

在使用第三方工具包时,有时由于文档不完整,需要跟踪源代码时,可以借助SequenceDiagram插件, 生成时序图,是代码跟踪更加清晰。

easyexcel 动态列_easyexcel动态表头列导出SequenceDiagram 阅读源码事半功倍相关推荐

  1. JavaScript实现跳跃游戏的动态编程自上而下的方法算法(附完整源码)

    JavaScript实现跳跃游戏的动态编程自上而下的方法算法(附完整源码) dpTopDownJumpGame.js完整源代码 dpTopDownJumpGame.test.js完整源代码 dpTop ...

  2. 代码式动态录入生成个人简历页面html页面前端源码

    大家好,今天给大家介绍一款,代码式动态录入生成个人简历页面html页面前端源码(图1).送给大家哦,获取方式在本文末尾. 图1 整个页面分为两个部分,左右布局,左边动态输入一个代码编辑器,根据输入的代 ...

  3. Openssl ECC椭圆曲线算法 - 密钥/签名/验签/加密/解密/SM2密文 - 序列化反序列化导出导入 - C源码

    . . . . 废话不多说,本代码继承自另外一位讲解Openssl ECC椭圆曲线算法大佬的源代码:https://blog.csdn.net/scuyxi/article/details/59182 ...

  4. Android Studio App开发之循环试图RecyclerView,布局管理器LayoutManager、动态更新循环视图讲解及实战(附源码)

    运行有问题或需要全部源码请点赞关注收藏后评论区留言~~~ 一.循环视图RecyclerView 尽管ListView和GridView分别实现了多行单列和多行多列的列表,使用也很简单,可是它们缺少变化 ...

  5. Android动态方式破解apk进阶篇(IDA调试so源码)

    一.前言 今天我们继续来看破解apk的相关知识,在前一篇:Eclipse动态调试smali源码破解apk 我们今天主要来看如何使用IDA来调试Android中的native源码,因为现在一些app,为 ...

  6. Android逆向之旅---动态方式破解apk进阶篇(IDA调试so源码)

    一.前言 今天我们继续来看破解apk的相关知识,在前一篇:Eclipse动态调试smali源码破解apk 我们今天主要来看如何使用IDA来调试Android中的native源码,因为现在一些app,为 ...

  7. 动态(视频)图像拼接和EDF景深融合解决方案(源码分享)

    如上图所示,4张局部清晰,并且照片右左右上下位移,大小缩放,EDF景深融合成一张清晰的图片,上图为示意图,可实现视频动态景深融合,实时视频状态,调节相机工作距离或者调节镜头焦距,自动合成清晰的图像 图 ...

  8. 实战突击JAVA开发项目_《实战突击Java项目开发案列整合》随书资料(视频+源码)_源雷技术空间...

    资源名称:<实战突击Java项目开发案列整合>随书资料(视频+源码) 资源目录: [IT教程网]第1-9_11-15_18_20_21章 [IT教程网]第10章BBS论坛 [IT教程网]第 ...

  9. Python量化投资——mplfinance最佳实践:动态交互式高级K线图(蜡烛图)【源码+详解】

    用mplfinance实现全功能动态交互式K线图 手把手用`python`+mplfinance实现高级K线图 ` mplfinance`的基本K线图 目标 实现自定义风格和颜色 图表尺寸调整.相关信 ...

最新文章

  1. golang笔记——struct
  2. 阿里中间件性能挑战赛启动,“开源”赛题独家剖析!
  3. hibernate更新部分字段的几种方法
  4. Bootstrap定制开发
  5. Mac上使用OpenCV【Xcode】
  6. java io-File
  7. 去西藏旅游一次要花多少钱,还有8/9月份去那边适合嘛?
  8. 又见The request sent by the client was syntactically incorrect ()
  9. 获取emf图片格式的方法
  10. QQ坦白说BUG 找出对方
  11. 面试系列-3 限流场景实践
  12. java 6面骰子_《剑指offer》 面试题43 n个骰子的点数 (java)
  13. 小白入门C语言之浮点数详解
  14. 一口气讲完设计模式(单例模式、工厂模式、原型模式、建造者模式、适配器、桥梁模式)
  15. 甲骨文中间件与主数据管理平台
  16. 如何以聪明的方式提问
  17. JAVA_OPTS设置
  18. 【计算机网络】PPP协议
  19. 云原生CI/CD:tekton/pipeline之认证篇
  20. 服务器硬盘选金盘好吗,WD 西部数据 企业级 10T金盘与8T金盘 对比测试

热门文章

  1. Java应用程序的简单令牌认证
  2. JDK 9:NotNullOrElse方法已添加到Objects类
  3. Java中的异步等待
  4. xtend怎么使用_使用Xtend构建Vaadin UI
  5. 带有Netflix Ribbon的Spring Cloud Rest Client-基础知识
  6. Java中集合的自定义运算符
  7. powermock模拟对象_使用PowerMock测试对象的内部状态
  8. Spring Batch作为Wildfly模块
  9. HashMap如何在Java中工作
  10. 精简SWT FormLayout的用法