【造轮子】打造一个简单的万能Excel读写工具
大家工作或者平时是不是经常遇到要读写一些简单格式的Excel?
shit!~很蛋疼,因为之前吹牛,就搞了个这东西,还算是挺实用,和大家分享下。
厌烦了每次搞简单类型的Excel读写?不怕~来,喜欢流式操作?来~,喜欢用lambda(虽然java的比较蛋疼~),来~看这个~
哈哈,如果你用的不是java8~~没问题,那就默默地用老方式匿名类来实现这些功能吧,但是这并不妨碍您的使用哈哈~~~
更新多次~希望大家也能够集思广益~
github地址:https://github.com/MatrixSeven/ExcelReads
欢迎大家fork,欢迎大家Star,更欢迎大家多提意见or建议,提供更好的想法~~
ExcelReads(简单Excel通用读写器)
ExcelReads是什么?
- 这是一个通用的简单的Excel读取器
- 支持自定义JavaBean实体读取和HashMap自动读取
- 支持自定义扩展
- 支持自定义Sheet范围,数据开始行数
- 支持数据库查询直接导出Excel(Map/Object)
- 支持正则过滤数据格式
- JavaBean实体支持使用注解添加正则规则校验,HashMap支持数组规则校验
- 依赖POI,使用Maven构建
更新纪录
更新2017/01/05
- 修复据库查询的导出(Object)递归越栈问题
- 增加新的xxx.Class定义类型导出,操作更简单
- 导出注解支持(自己使用seven.savewapper.anno.ExcelAnno类型注解)
更新2017/01/04
- 修复据库查询的导出(Map)空指针&下标越界问题
- 修复在Filter数据后出现空行问题
- 丢入Result参数后的操作就如同操作Map/Object一样
更新2017/01/01
- 增加ResExprotDBMap&ResExprotDBObj用于支持数据库导出
- 支持基于数据库查询的导出(Map),直接放入Result对象即可
- 支持基于数据库查询的导出(Object),直接放入Result对象即可
更新2016/11/30
- 增加了简单类型得写入,生成xls/xlsx
- 直接JavaBean类型写入,注解命名
- 支持Map key-value类型写入
- 写入时支持和读取一样得过滤加工排序等写法
更新2016/11/29
- 增加CreateMap By Key
- 去除无用泛型
- 增加xlsx支持
更新2016/11/8
- 支持数据过滤和处理是转换,基于事件模式
- 更新为Build模式创建实例
- 增加数据过滤、数据转换和数据排序回调接口
- 采用链式set方式进行
其他
- 自定义读取支持出简单的规范化数据格式,即典型的表头格式
- 可以继承 WapperMap 和 WapperObj进行扩展
- 直接使用ExcelFactory.getBeans进行获取,WapperObj则自己添加泛型
- 注解Value对应列标题,Required对应正则,可自己写正则表达式或者直接使用RegHelper
- 实体bean数据要比hashMap慢,7w条数据慢800ms,加入正则减慢速度(测试中加入了正则)
使用方法说明
- 本程序只能读取简单格式的xls文件,文件布局如下(标准的行列结构):
| 标题1 | 标题2 | 标题3 |
|---|---|---|
| foo | foo | foo |
| bar | bar | bar |
| baz | baz | baz |
数据库导出自定义Bean类型写法(xxx.Class类型)
ExcelFactory.saveExcel(
UNPOOLED_DATA_SOURCE.getConnection().
prepareStatement("select * FROM users_info limit 1000").executeQuery(),
"\u5317\u4eac__Excel.xlsx",
AS.class)
.FilterCol(() -> new String[]{"updatetime"})
.Filter((AS o) ->o.getA().length() > 3)
.Save();
数据库导出自定义Bean类型写法(自己实现包装)
ExcelFactory.saveExcel(
UNPOOLED_DATA_SOURCE.getConnection().
prepareStatement("select * FROM users_info limit 1000").executeQuery(),
"\u5317\u4eac__Excel.xlsx",
res -> {
AS a = new AS();
a.setA(res.getString("name"));
return a;
})
.FilterCol(() -> new String[]{"updatetime"})
.Filter((AS o) ->o.getA().length() > 3)
.Save();
数据库直接导出到Excel例子
ExcelFactory.saveExcel(
UNPOOLED_DATA_SOURCE.getConnection().
prepareStatement("select * FROM users_info limit 10000").
executeQuery(), "知乎导出Excel.xlsx")
//过滤字段
.FilterCol(() -> new String[]{"updatetime"})
//过滤数据条件
.Filter((HashMap<String, String> o) ->
o.get("address").equals("\u5317\u4eac"))
.Save();
自定义类型导出到Excel例子
List<A> aa = new ArrayList<>();
aa.add(new A("a", "b"));
aa.add(new A("aa", "bb"));
ExcelFactory.saveExcel(aa,
System.getProperty("user.dir").concat("\\Save.xlsx"))
///这里能够处理每一行数据
.Process((A a) -> a.setA("xxxxxxx"))
//过滤列
.FilterCol(() -> new String[]{"B"})
//根据某个字段来处理数据时候丢弃
.Filter((A a) -> a.getA().length() > 1)
//排序
.Sort((A o1,A o2 ) -> o1.getAge()>o2.getAge()?1:o1.getAge()==o2.getAge()?0:-1)
.Save();
读取Excel到Map例子
List<Map<String,String>> data=ExcelFactory.getBeans(System.getProperty("user.dir").concat("\\测试.xls"),
new ResWrapperMap() {
@Override//配置Excel属性
protected void LoadConfig(Config config) {
config.setContent_row_start(3);
config.setTitle_row(2);
}
}).//这里能够处理每一行数据
Process((HashMap<String, String> o) -> System.out.println(o + "\n")
//这里能够处理时候过滤某一列
).FilterCol(() -> new String[]{}
//这里能根据某一行的某一列的内容来取舍这行数据
).Filter((HashMap<String, String> o) -> o.get("创建人") != null && o.get("创建人").length() > 5
//排序
).Sort((o1, o2) -> o1.hashCode()>o2.hashCode()?1:hashCode()==o2.hashCode()?0:-1).Create();
//使用 .CreateMap(key_v) 生成Map<Key,Map>类型数据
读取Excel到自定义类型的例子
Map<String,Seven> map=new ResWrapperObj(Seven) {
@Override
protected void LoadConfig(Config config) {
config.setContent_row_start(3);
config.setTitle_row(2);
}
}).
Process((HashMap<String, String> o) -> {}
).FilterCol(() -> new String[]{}
).Filter((HashMap<String, String> o) -> o.get("创建人") !=
null &&o.get("创建人").length() > 4).<Map>CreateMap("创建人"));
- 邮件(hacker.kill07@gmail.com)
- QQ: 985390927
- weibo: @Alden_情绪控
- Blog: http://sweets.cf
【造轮子】打造一个简单的万能Excel读写工具的更多相关文章
- 动手造轮子:实现简单的 EventQueue
动手造轮子:实现简单的 EventQueue Intro 最近项目里有遇到一些并发的问题,想实现一个队列来将并发的请求一个一个串行处理,可以理解为使用消息队列处理并发问题,之前实现过一个简单的 Eve ...
- [.NET] 一步步打造一个简单的 MVC 网站 - BooksStore(一)
一步步打造一个简单的 MVC 网站 - BooksStore(一) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore 简介 主 ...
- [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(二)
一步步打造一个简单的 MVC 电商网站 - BooksStore(二) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore 前: ...
- [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(三)
一步步打造一个简单的 MVC 电商网站 - BooksStore(三) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...
- [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(四)
一步步打造一个简单的 MVC 电商网站 - BooksStore(四) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...
- [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(一)
一步步打造一个简单的 MVC 电商网站 - BooksStore(一) 本系列的 GitHub地址:https://github.com/liqingwen2015/Wen.BooksStore &l ...
- [.NET] 一步步打造一个简单的 MVC 电商网站 - BooksStore(一) (转)
http://www.cnblogs.com/liqingwen/p/6640861.html 一步步打造一个简单的 MVC 电商网站 - BooksStore(一) 本系列的 GitHub地址:ht ...
- Css打造一个简单的静态七巧板
偶然在微博上看到用css写一个七巧板,正好也有一些源代码,于是就试着敲了敲. 主要是利用了css3的transform,实现平移,旋转,变形,直接用看到的代码敲出来之后有些问题,因为宽度上下面绿色的三 ...
- Flutter随笔(二)——使用Flutter Web + Docker + Nginx打造一个简单的Web项目
前言 Flutter作为一个跨平台UI框架,功能十分强大,仅用一套代码便能编译出Android.iOS.Web.windows.macOS.Windows.Linux等平台上的应用,各平台应用体验高度 ...
随机推荐
- Linq表达式、Lambda表达式你更喜欢哪个?
什么是Linq表达式?什么是Lambda表达式? 如图: 由此可见Linq表达式和Lambda表达式并没有什么可比性. 那与Lambda表达式相关的整条语句称作什么呢?在微软并没有给出官方的命名,在& ...
- Web性能优化:What? Why? How?
为什么要提升web性能? Web性能黄金准则:只有10%~20%的最终用户响应时间花在了下载html文档上,其余的80%~90%时间花在了下载页面组件上. web性能对于用户体验有及其重要的影响,根据 ...
- clr 元数据
clr相关编译器编译生成的托管模块由四部分组成:PE32或32+头.clr头.元数据.IL代码. 元数据和IL代码完全对应,保持一致(:>)性. 元数据有很多用途: VS的智能感知,自动补全: ...
- [原] KVM 虚拟化原理探究(4)— 内存虚拟化
KVM 虚拟化原理探究(4)- 内存虚拟化 标签(空格分隔): KVM 内存虚拟化简介 前一章介绍了CPU虚拟化的内容,这一章介绍一下KVM的内存虚拟化原理.可以说内存是除了CPU外最重要的组件,Gu ...
- [原]分享一下我和MongoDB与Redis那些事
缘起:来自于我在近期一个项目上遇到的问题,在Segmentfault上发表了提问 知识背景: 对不是很熟悉MongoDB和Redis的同学做一下介绍. 1.MongoDB数组查询:MongoDB自带L ...
- 脑洞大开之采用HTML5+SignalR2.0(.Net)实现原生Web视频
目录 对SignalR不了解的人可以直接移步下面的目录 SignalR系列目录 前言 - -,我又来了,今天废话不多说,我们直接来实现Web视频聊天. 采用的技术如下: HTML5 WebRTC Si ...
- 设计模式C#合集--单例模式
单例模式 代码: 第一种: private static Singleton singleton = null; private Singleton() { } public static Singl ...
- spider RPC入门指南
本部分将介绍使用spider RPC开发分布式应用的客户端和服务端. spider RPC中间件基于J2SE 8开发,因此需要确保服务器上安装了JDK 8及以上版本,不依赖于任何额外需要独立安装和配置 ...
- 深入理解DOM节点操作
× 目录 [1]创建节点 [2]插入节点 [3]移除节点[4]替换节点[5]复制节点 前面的话 一般地,提起操作会想到“增删改查”这四个字,而DOM节点操作也类似地对应于此,接下来将详细介绍DOM的节 ...
- Supermap iCloudManager -负载均衡
Supermap icm负载均衡理解: 应用场景:地图出图 子节点1和子节点2中的服务保持一致,一般情况下设置的是匿名用户通过nginx访问服务信息,所以不需要登录. 1.通过nginx分发请求,(轮 ...