excel和word 简易工具类,jeasypoi 2.1.5 版本发布
摘要:
jeasypoi 功能如同名字easy,主打的功能就是容易,让一个没见接触过poi的人员 就可以方便的写出excel导出,excel模板导出,excel导入,word模板导出,通过简单的注解和模板 语言(熟悉的表达式语法),完成以前复杂的写法。
主要特点:
1.设计精巧,使用简单
2.接口丰富,扩展简单
3.默认值多,write less do more
4.abstractview 支持,web导出可以简单明了
一、升级日志
- 一对多表结构导入导出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
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.settemplate;
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);