博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Excel和Word 简易工具类,JEasyPoi 2.1.5 版本发布
阅读量:7176 次
发布时间:2019-06-29

本文共 4895 字,大约阅读时间需要 16 分钟。

  hot3.png

Excel和Word 简易工具类,JEasyPoi 2.1.5 版本发布 

摘要:

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

    主要特点:

          1.设计精巧,使用简单
          2.接口丰富,扩展简单
          3.默认值多,write less do more
          4.AbstractView 支持,web导出可以简单明了

 

一、升级日志

Excel和Word简易工具类,可以无缝集成springmvc,也为jeecg快速开发平台提供更便捷的,强大的导入导出。

  • 一对多表结构导入导出BUG修正;
  • jeecg 个性化定制版;
  • 支持配置jeecg字典code 翻译导出;
  • 支持自定义字典扩展接口,方便用户自定义;
  • 大数据导入导出优化;

二、在线WIKI文档

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

     

        后面都是新的了

三、JEasyPoi 集成方法

           1.   采用 maven方式

                  在pom.xml 引入以下依赖。配置私服

org.jeecgframework
jeasypoi-base
2.1.5
org.jeecgframework
jeasypoi-web
2.1.5
org.jeecgframework
jeasypoi-annotation
2.1.5

 

2. 非maven方式

  直接拷贝相关jar进项目Lib中

 

四、源码下载

                

                     

五、技术交流

  •  技术论坛:
  •  QQ交流群: ⑥190866569、⑤ 293658367、④176031980(满)、②106838471(满)
  •  在线体验:   

六、测试实战

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);

转载于:https://my.oschina.net/jeecg/blog/1795164

你可能感兴趣的文章
Redis和Memcache的区别分析(转)
查看>>
网络请求 http get post 一
查看>>
《计算机问题求解》总结——2014年CCF计算机课程改革导教班(2014.07.11)
查看>>
Google Chrome Plus——绿色便携多功能谷歌浏览器
查看>>
Instant Run
查看>>
浏览器中 for in 反射 对象成员 的差异
查看>>
关于Linux启动时挂载rootfs的几种方式
查看>>
2018年总结
查看>>
34个漂亮的应用程序后台管理界面
查看>>
java JDK6的可变参数
查看>>
初入职场程序员的五大钻石法则
查看>>
Node.js学习笔记(一)概述
查看>>
split的3种方法
查看>>
忽略PNG透明区域的事件(AS/Flash)
查看>>
文本框只能输入正整数(大于0的整数)代码
查看>>
一步一个脚印学习WCF系列之WCF概要—WCF服务的创建与调用HelloWorld实例,通过配置文件方式(六)...
查看>>
只需简单一步,android自带的示例程序 BluetoothChat 变蓝牙串口助手
查看>>
thrift之TTransport层的内存缓存传输类TMemoryBuffer
查看>>
使用pull方式解析xml文件示例:
查看>>
学习jQuery的免费资源:电子书、视频、教程和博客
查看>>