论坛首页 Java企业应用论坛

Excel导入导出组件

浏览 31042 次
精华帖 (2) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-11-30  

        当前的程序开发中(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

 

  • Excel.rar (11 KB)
  • 描述: 源代码
  • 下载次数: 2612
   发表时间:2007-12-01  
有个问题不明白:column :指excel没有表头名称时,可以对应所排的列号 是啥意思? Excel文件: 部门名称 部门编号 发文简称 排序 操作结果 (没有这一行?) 总部 A001 永久 2 00000 一分部 A002 长期 3 111111 分部 A003 长期 5
0 请登录后投票
   发表时间:2007-12-01  
有个问题不明白:
column :指excel没有表头名称时,可以对应所排的列号 是啥意思?

Excel文件:
部门名称 部门编号 发文简称 排序 操作结果 (没有这一行?)
总部 A001 永久 2 00000
分部 A002 长期 3 111111
分部 A003 长期 5
0 请登录后投票
   发表时间:2007-12-01  
godson_2003 写道
有个问题不明白:
column :指excel没有表头名称时,可以对应所排的列号 是啥意思?

Excel文件:
部门名称 部门编号 发文简称 排序 操作结果 (没有这一行?)
总部 A001 永久 2 00000
分部 A002 长期 3 111111
分部 A003 长期 5
column:这个版本还没有支持。指属性值取Excel第几列的值。有两各方式取值:一是按配制文件中ExcelTitleName对应Excel中的列标题取值,二是按column对应的Excel中第几列取值。
操作结果:可以去掉,是新功能测试的数据。那是用来做错误信息回写的。(在web应用中,正确的数据写入到数据库中,当有验证未通过的记录时,把错误原因写入到Excel中,再回传给用户。这些是导入不成功的数据。)

map 中传入的是当一列数据有对应的代码表,需要替换。如:长期(C),永久(Y) 长期是显示值,Y是数据库中保存的值
<property name="sendFileName" column="3" excelTitleName="发文简称" dataType="String" maxLength="15" fixity="" codeTableName="bgqx" default="C"/>

map.put("deptNo", "1");
map.put("bgqx永久", "Y");


0 请登录后投票
   发表时间:2007-12-01  
看一下:com\javayjm\excel\config\ConfigConstant.java
package com.javayjm.excel.config;

public class ConfigConstant {

/*
* model 的查找编号  id
*/
public static final String MODEL_ID = "id";

/*
* 从Excel 到 Model 转换的目标 javabean class
*/
public static final String MODEL_CLASS="class";

/*
* excel 列中对应到javabean中的 javabean属性名称
*/
public static final String PROPERTY_NAME = "name";

/*
* excel中的标标题中的列数 (  取值的时候可以用javabean属性和对应的列数取值)
*/
public static final String PROPERTY_CLOUMN="cloumn";

/*
* excel 列中对应到javabean中的 excel列标题名称  (取值的时候,可以用 javabean属性和Excel中的标题对应取值)
*/
public static final String PROPERTY_EXCEL_TITLE_NAME = "excelTitleName";

/*
* excel中的列数据要被转换的数据类型
*/
public static final String PROPERTY_DATA_TYPE = "dataType";

/*
* excel中的数据最大长度
*/
public static final String PROPERTY_MAX_LENGTH="maxLength";

/*
* 在excel中没有列数据,需要系统对javabean属性中的某一个值设置一个动态传入的值(指所有JavaBean的这个属性值,都是统一传入的固定值).设置些属性,必须设置默认值
*
* 他的值设置为 fixity = "yes" ,默认为 no.
*/
public static final String PROPERTY_FIXITY="fixity";

/*
* 在导入excel时,有些值在存入系统时,使用的值需要转换
* 如:一个保管期限的下拉列表中有{永久(Y),长期(C),短期(D)}
* 系统中存入的只能是 Y,C,D之类的值,导入Excel的值却是永久,长期,短期这类的值,需要转换.
* 转换方式:取到Excel中的具体值,加上保管期限前辍,从传入的Map中取值.如 取值长期  C = Map.get("bgqx长期");
*
*/
public static final String PROPERTY_CODE_TABLE_NAME="codeTableName";
/*
* 如果值为空,设置的默认值
*/
public static final String PROPERTY_DEFAULT="default";
}
0 请登录后投票
   发表时间:2007-12-05  
这个组件的设计思想还是很清楚的。
XML配置数据库字段和EXCEL各列的映射关系,
ExcelToModel通过JXL解析文件,根据配置每行生成JAVABEAN
遍历得到list

谢谢楼主,晚上回去试试
0 请登录后投票
   发表时间:2007-12-05  
pandaprince 写道

XML配置数据库字段和EXCEL各列的映射关系



XML配置javaBean属性和EXCEL各列的映射关系,别走弯路。
一些新功能正在开发中。
0 请登录后投票
   发表时间:2007-12-06  
apache 的 pol 好像也可以实现类似的功能。
0 请登录后投票
   发表时间:2007-12-06  
不好意思,是 POI 不是POL
0 请登录后投票
   发表时间:2007-12-12  
问题是有些EXCEL文档 的格子是 不规律的
比如遇到单元格是合并的 那如何判断?
0 请登录后投票
论坛首页 Java企业应用版

跳转论坛:
Global site tag (gtag.js) - Google Analytics