POI 工具类,Excel的快速导入导出,Excel模板导出,Word模板导出,可以仅仅5行代码就可以完成Excel的导入导出,修改导出格式简单粗暴,快速有效,easypoi值得你尝试 http://www.jeecg.org/

README.md 12.06 KB

=========================== EasyPoi Excel和 Word简易工具类

easypoi功能如同名字easy,主打的功能就是容易,让一个没见接触过poi的人员 就可以方便的写出Excel导出,Excel模板导出,Excel导入,Word模板导出,通过简单的注解和模板 语言(熟悉的表达式语法),完成以前复杂的写法

作者博客:http://blog.csdn.net/qjueyue

作者邮箱: qrb.jueyue@gmail.com

QQ群: 364192721

测试项目: http://git.oschina.net/jueyue/easypoi-test

EasyPoi的主要特点

1.设计精巧,使用简单

2.接口丰富,扩展简单

3.默认值多,write less do more

4.AbstractView 支持,web导出可以简单明了

EasyPoi的几个入口工具类

1.ExcelExportUtil Excel导出(

普通导出,模板导出)

2.ExcelImportUtil Excel导入

3.WordExportUtil Word导出(只支持docx ,doc版本poi存在图片的bug,暂不支持)

关于Excel导出XLS和XLSX区别

1.导出时间XLS比XLSX快2-3倍

2.导出大小XLS是XLSX的2-3倍或者更多

3.导出需要综合网速和本地速度做考虑^~^

几个工程的说明

1.easypoi 父包--作用大家都懂得

2.easypoi-annotation 基础注解包,作用与实体对象上,拆分后方便maven多工程的依赖管理

3.easypoi-base 导入导出的工具包,可以完成Excel导出,导入,Word的导出,Excel的导出功能

4.easypoi-web 耦合了spring-mvc 基于AbstractView,极大的简化spring-mvc下的导出功能

5.sax 导入使用xercesImpl这个包(这个包可能造成奇怪的问题哈),word导出使用poi-scratchpad,都作为可选包了

maven

org.jeecg

easypoi-base

2.1.3

org.jeecg

easypoi-web

2.1.3

org.jeecg

easypoi-annotation

2.1.3

版本修改

2.1.3

屏蔽了科学计数法的问题

修复了多模版记得清空记录信息

加入了map setValue的接口,用以自定义setValue,主要是可以自定义key

把合并单元格的数据提起出来,让大家都可以复用

多个sheet导出问题

2.1.2

groupId 改成org.jeecg,为了以后可以直接提交到中央库了

把test 那个模块删除了

提供了Excel 预览的功能

type 新增一个 4类型,用于Excel是数字,但是java 是String,防止科学计数法

修复一些bug

2.1.1-release -小更新/防止下一个预览功能太久不能发布更新

$fe标签

几个可能影响使用的bug

导入Map的支持

2.0.9-release--模板功能更新

修复了中文路径,float类型导入等bug

增加了根据CellStyler判断cell类型的功能

优化了一下代码,sort 的compare 改为类实现接口,getValue统一由public处理

height和width 都改成double 可能更加准确的调整

升级到common-lang3

可以循环解析多个模板

!!模板增加了多个标签功能

2.0.8-release--小版本更新

分开了基础注解和base包,编译maven多模块集成

加强了Excel导入的校验功能,可以追加错误信息,过滤不合格数据

修复了spring mvc下的07版本不支持的问题

添加了@ Controller 注解,扫描org.jeecgframework.poi.excel.view路径就可以了,不用写bean了

加强了styler的自定义功能,参数改为entity,自由控制

test包下面增加了几个demo

导出添加了一个冰冻列属性,可以简单执行

PS: 经过这段时间项目中的测试,模板导出Excel复杂报表可以省5倍以上的时间,特别是样式复杂的完全可以在Excel中完成,不是在代码中完成了

2.0.7-release--推荐更新

增加了合计的参数,便于统计合计信息

修改了样式设置,使用默认设置,提供其他设置,和样式接口

模板导出增加了插入导出的功能

模板导出重用了Excel导出的代码功能更加强劲

新增了Sax导入方式,大数据导入提供接口操作

Word修改了页眉页脚不替换的bug

修改了捕获异常日志的bug

修复了模板导出,Spring View没识别版本的bug

修复了其他一些小bug

2.0.6-release

修复导入的自定义格式异常

修复导入的BigDecimal不识别

导出大数据替换为SXSSFWorkbook,提高07版本Excel导出效率

根据sonar的提示,修复编码格式问题

做了更加丰富的测试

word 导出的优化

2.0.6-SNAPSHOT

增加map的导出

增加index 列

EasyPoi 文档

这几篇是旧的教程,不过和现在大同小异

后面都是新的了

EasyPoi 模板 表达式支持

空格分割

三目运算 {{test ? obj:obj2}}

n: 表示 这个cell是数值类型 {{n:}}

le: 代表长度{{le:()}} 在if/else 运用{{le:() > 8 ? obj1 : obj2}}

fd: 格式化时间 {{fd:(obj;yyyy-MM-dd)}}

fn: 格式化数字 {{fn:(obj;###.00)}}

fe: 遍历数据,创建row

!fe: 遍历数据不创建row

$fe: 下移插入,把当前行,下面的行全部下移.size()行,然后插入

!if: 删除当前列 {{!if:(test)}}

单引号表示常量值 '' 比如'1' 那么输出的就是 1

EasyPoi导出实例

1.注解,导入导出都是基于注解的,实体上做上注解,标示导出对象,同时可以做一些操作

@ExcelTarget("courseEntity")

public class CourseEntity implements java.io.Serializable {

/** 主键 */

private String id;

/** 课程名称 */

@Excel(name = "课程名称", orderNum = "1", needMerge = true)

private String name;

/** 老师主键 */

@ExcelEntity(id = "yuwen")

@ExcelVerify()

private TeacherEntity teacher;

/** 老师主键 */

@ExcelEntity(id = "shuxue")

private TeacherEntity shuxueteacher;

@ExcelCollection(name = "选课学生", orderNum = "4")

private List students;

2.基础导出 传入导出参数,导出对象,以及对象列表即可完成导出

HSSFWorkbook workbook = ExcelExportUtil.exportExcel(new ExportParams(

"2412312", "测试", "测试"), CourseEntity.class, list);

3.基础导出,带有索引 在到处参数设置一个值,就可以在导出列增加索引

ExportParams params = new ExportParams("2412312", "测试", "测试");

params.setAddIndex(true);

HSSFWorkbook workbook = ExcelExportUtil.exportExcel(params,

TeacherEntity.class, telist);

4.导出Map 创建类似注解的集合,即可完成Map的导出,略有麻烦

List entity = new ArrayList();

entity.add(new ExcelExportEntity("姓名", "name"));

entity.add(new ExcelExportEntity("性别", "sex"));

List> list = new ArrayList>();

Map map;

for (int i = 0; i < 10; i++) {

map = new HashMap();

map.put("name", "1" + i);

map.put("sex", "2" + i);

list.add(map);

}

HSSFWorkbook workbook = ExcelExportUtil.exportExcel(new ExportParams(

"测试", "测试"), entity, list);

5.模板导出 根据模板配置,完成对应导出

TemplateExportParams params = new TemplateExportParams();

params.setHeadingRows(2);

params.setHeadingStartRow(2);

Map map = new HashMap();

map.put("year", "2013");

map.put("sunCourses", list.size());

Map obj = new HashMap();

map.put("obj", obj);

obj.put("name", list.size());

params.setTemplateUrl("org/jeecgframework/poi/excel/doc/exportTemp.xls");

Workbook book = ExcelExportUtil.exportExcel(params, CourseEntity.class, list,

map);

6.导入 设置导入参数,传入文件或者流,即可获得相应的list

ImportParams params = new ImportParams();

params.setTitleRows(2);

params.setHeadRows(2);

//params.setSheetNum(9);

params.setNeedSave(true);

long start = new Date().getTime();

List list = ExcelImportUtil.importExcel(new File(

"d:/tt.xls"), CourseEntity.class, params);

7.和spring mvc的无缝融合 简单几句话,Excel导出搞定

@RequestMapping(params = "exportXls")

public String exportXls(CourseEntity course,HttpServletRequest request,HttpServletResponse response

, DataGrid dataGrid,ModelMap map) {

CriteriaQuery cq = new CriteriaQuery(CourseEntity.class, dataGrid);

org.jeecgframework.core.extend.hqlsearch.HqlGenerateUtil.installHql(cq, course, request.getParameterMap());

List courses = this.courseService.getListByCriteriaQuery(cq,false);

map.put(NormalExcelConstants.FILE_NAME,"用户信息");

map.put(NormalExcelConstants.CLASS,CourseEntity.class);

map.put(NormalExcelConstants.PARAMS,new ExportParams("课程列表", "导出人:Jeecg",

"导出信息"));

map.put(NormalExcelConstants.DATA_LIST,courses);

return NormalExcelConstants.JEECG_EXCEL_VIEW;

}

8.Excel导入校验,过滤不符合规则的数据,追加错误信息到Excel,提供常用的校验规则,已经通用的校验接口

/**

* Email校验

*/

@Excel(name = "Email", width = 25)

@ExcelVerify(isEmail = true, notNull = true)

private String email;

/**

* 手机号校验

*/

@Excel(name = "Mobile", width = 20)

@ExcelVerify(isMobile = true, notNull = true)

private String mobile;

ExcelImportResult result = ExcelImportUtil.importExcelVerify(new File(

"d:/tt.xls"), ExcelVerifyEntity.class, params);

for (int i = 0; i < result.getList().size(); i++) {

System.out.println(ReflectionToStringBuilder.toString(result.getList().get(i)));

}

9.导入Map 设置导入参数,传入文件或者流,即可获得相应的list,自定义Key,需要实现IExcelDataHandler接口

ImportParams params = new ImportParams();

List> list = ExcelImportUtil.importExcel(new File(

"d:/tt.xls"), Map.class, params);

easypoi教程_Easy_Poi使用教程相关推荐

  1. easypoi教程_SpringBoot图文教程17—上手就会 RestTemplate 使用指南

    有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1-Spr ...

  2. php更改asp.net教程,ASP.NET 教程

    ASP.NET 是一个使用 HTML.CSS.JavaScript 和服务器脚本创建网页和网站的开发框架. ASP.NET 支持三种不同的开发模式: Web Pages(Web 页面).MVC(Mod ...

  3. serv-u 自定义html,Serv-U架设教程_Serv-U使用教程图文版

    Serv-U是一款很好用的FTP服务器软件,本文就给大家详细介绍一下<Serv-U架设教>,希望对广大新手有用. Serv-U架设教程_Serv-U使用教程图文版: 1.到文末下载 Ser ...

  4. UML基础教程(内部使用教程) 非常不错的ppt!!强烈推荐

    UML基础教程(内部使用教程) 非常不错的ppt http://wenku.baidu.com/view/66de89d63186bceb19e8bb1e.html 大家可以参考下 目录 1. 前言 ...

  5. C#游戏开发快速入门教程Unity5.5教程

    C#游戏开发快速入门教程Unity5.5教程 试读文档下载地址:http://pan.baidu.com/s/1slwBHoD C#是微软发布的高级程序设计语言,这门语言和C语言一样,已经成为了大学计 ...

  6. python语言教程-Python 基础教程

    Python基础教程 Python是一种解释型.面向对象.动态数据类型的高级程序设计语言. Python由Guido van Rossum于1989年底发明,第一个公开发行版发行于1991年. 像Pe ...

  7. python菜鸟教程h-python菜鸟教程,python好玩又简单的代码

    如果是零基础的话推荐你看以下几本书,入门来说都还不错:"笨办法"学Python(第3版)HeadFirstPython(中文版)父与子的编程之旅:与小卡特一起学Python pyt ...

  8. TensorFlow教程之完整教程 2.7 字词的向量表示

     TensorFlow教程之完整教程 2.7 字词的向量表示 知与谁同 2017-08-22 15:37:40 浏览67 评论0 函数 摘要: 本文档为TensorFlow参考文档,本转载已得到T ...

  9. mysql5 7安装教程_MySQL57安装教程

    MySQL57安装教程... --------------------------- 首先需要下载MySQL57安装包: --------------------------------------- ...

最新文章

  1. FPGA多功能应用处理器
  2. 必知必会的微服务面试题
  3. Abra宣布对BCH的原生支持
  4. oracle 同义词_Oracle迁移到MySQL,必须要搞明白这几个问题
  5. J2EE项目代码编写规范分享
  6. React文档(五)组件和props
  7. ActiveReports 报表控件V12新特性 -- 新增JSON和CSV导出
  8. 25 WM配置-策略-入库策略5-定义托盘策略P(Pallet Strategy)
  9. python函数使用两个小括号
  10. gc问题mysql连接池_数据库连接池引起的FullGC问题,看我如何一步步排查、分析、解决...
  11. 数据库(基础SQL)
  12. 亮度,对比度,饱和度,锐度对最终图像效果的影响
  13. 12.2总结(纵使结局不如意,放弃实属下下签。)
  14. 初中使用计算机教学反思,谈初中信息技术教学反思
  15. strtok函数的使用
  16. filecoin space race
  17. 数据中心等级T1,T2,T3,T4,T5区别,科普数据中心等级知识
  18. Vue 删除列表项的淡出动画
  19. apq 8064 uart debug
  20. role=“presentation“啥意思

热门文章

  1. android tv wifi设置密码,android TV版 wifi 压力测试
  2. 人民币国际化推进债市双向开放
  3. BUG被称为计算机错误的来源
  4. 【最强解决办法】日式打印图片显示不全(word预览却是全的),打印画质下降、转PDF下降等问题
  5. Handler机制——同步屏障
  6. prometheus杂碎
  7. 记一次--冲动租房--搞得身心疲惫
  8. Excel中文转拼音(完整版)
  9. 乘复兴号返京,响应无穷小呼唤
  10. 子弹短信怎么就一夜爆火了呢??