Excel导入导出组件

        当前的程序开发中(Struts + Spring + Hibernate/Ibatis),有很多需要用Excel文件进行数据的导入,导出操作。
不同的人有不同的处理方式,我也尝试过一些方法,但是Excel文件不确定的情况下总是有些变动,每次都要修改程序。
于是就想能不能把Excel文件每行记录填充成一个javaBean,封装成一个List返回,然后把List交给Hibernate/Ibatis来处理。
如果Excel文件有什么小的变动,只需要修改配制文件就可以解决呢。

可以,产生一个xml配制文件,在配制文件中,把excel中的每一列和javabean中的属性对应些来,就可以解决啦。

1、Excel组件可以把现有的格式化的Excel文件每笔记录填充指定的JavaBean,封装成一个List返回给用户。用户可以利用封装之后的javabean list 进行相关操作(交给hibernate,ibatis等处理)。
2、技术来源于网络,回归于网络。但这种设计的想法,希望能给大家带来方便。
3、本人技术有限,请各位朋友多多指教。

实例说明:
Excel文件:

部门名称部门编号发文简称排序操作结果
总部A001永久200000
一分部A002长期3111111
分部A003长期5 

 


目标:对每行记录转换成JavaBean,封装一个List返回给用户。


XML配制:

<?xml version="1.0" encoding="UTF-8" ?>
<models>
 <model id="deptModel" class="com.javayjm.test.model.DeptModel">
  <property name="deptName" column="1" excelTitleName="部门名称" dataType="String" maxLength="15" fixity="" codeTableName="" default=""/>
  <property name="deptCode" column="2" excelTitleName="部门编号" dataType="String" maxLength="15" fixity="" codeTableName="" default=""/>
  <property name="sendFileName" column="3" excelTitleName="发文简称" dataType="String" maxLength="15" fixity="" codeTableName="bgqx" default="C"/>
  <property name="deptNo" column="4" excelTitleName="排序" dataType="String" maxLength="15" fixity="yes" codeTableName="" default="10"/>
 
 </model>
 
 <!-- column :指excel没有表头名称时,可以对应所排的列号 -->
</models>



实例调用:

  Map map = new HashMap();
  map.put("deptNo", "1");
  map.put("bgqx永久", "Y");
  ExcelManager test = new ExcelManager("E:\\workspace\\test.xls","deptModel",map);
  List modelList = test.getModelList();

System.out.println("--" + ToStringBuilder.reflectionToString(test.getConfigTitle().entrySet().toArray()));
  
  for(int i = 0;i    Object obj = modelList.get(i);
   System.out.println("--" + obj.getClass().getSimpleName());
   System.out.println("--" + ToStringBuilder.reflectionToString(obj));
  }

输出结果:

init Class = com.javayjm.test.model.DeptModel
init Class = com.javayjm.test.model.DeptModel
init Class = com.javayjm.test.model.DeptModel
--[Ljava.lang.Object;@4413ee[{deptName=部门名称,deptCode=部门编号,deptNo=排序,sendFileName=发文简称}]
--DeptModel
--com.javayjm.test.model.DeptModel@197a37c[id=0,deptName=总部,deptCode=A001,sendFileName=Y,receiveFileName=,deptNo=1,flag=0,message=]
--DeptModel
--com.javayjm.test.model.DeptModel@17fa65e[id=0,deptName=分部中华人民共各国万元日期要分,deptCode=A002,sendFileName=C,receiveFileName=,deptNo=1,flag=0,message=]
--DeptModel
--com.javayjm.test.model.DeptModel@18385e3[id=0,deptName=分部,deptCode=A003,sendFileName=C,receiveFileName=,deptNo=1,flag=0,message=]

 

 

lib 清单

 

commons-lang-2.0.jar
commons-logging.jar
dom4j-1.6.jar
jxl.jar
log4j-1.2.8.jar
spring.jar

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值