`
nanyjm
  • 浏览: 9519 次
社区版块
存档分类
最新评论

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

 

  • Excel.rar (11 KB)
  • 描述: 源代码
  • 下载次数: 2612
分享到:
评论
21 楼 guooscar 2008-10-31  
其实可以考虑的深一点。
转换的工作其实就是一个讲多行数据到对象列表的过程。
可以将多种不同的数据来源抽象成数据源
比如说
interface DataSource{
     boolean hasNext();
     String[] next();
}
然后在用一个转换器讲数据源提供的数据转换成对象列表。这个过程可以使用
反射(或者动态字节码生成),自动检测每个属性的类型,然后设置一套转换器,来进行String到Object的转换。
当然在转换器中还可以添加一些Listener Filter之类的东东,这样就能更方便的控制转换过程。
我已经基本实现了这样的一套东西,准备过几天放到sourceforge上。
20 楼 yanjiajun 2008-10-31  
曾经在项目中也做了一个类似的excel导入功能。当时做得比较简单,excel列到VO的转换协议是直接写在excel标题中了。。没有你做的细致,感谢你的工作,值得参考
19 楼 fuliang 2008-01-13  
曾经使用泛型做的,一个通用的Excel和Javabean相互转换的东东。
写到Excel的时候很容易,读的时候可以考虑使用Spring的BeanWapper
和PropertyEditor来把字符串类型进行转换,转化成javabean。
18 楼 xianglei 2008-01-13  
最好用poi对多语言支持比较好!!
17 楼 nanyjm 2008-01-11  
myyate 写道
楼主,看了你的代码不错,比我简洁多了。
我最近也写了类似的基础包,做一个通用程序,在web系统中把查询的数据导出到Excel和把上传过来的Excel数据导入DB。也是通过类似的XML配置Excel列和Dto(临时存放)成员对应。
我提几点与你交流一下:
1,既然你这个是要导入到DB中,就要有验证,我看你代码的验证主要是根据property元素里设置类似dataType、maxLength...来限制的,这样验证功能有限,比如还有某些列他的值是一些固定的值、日期必须符合yyyy-MM-dd...;还有比如你的部门,在Excel中用户她选择一些具体的部门名称,而不是编号之类,这个时候也需要验证这个部门名称是否合法?这些您是如何验证的?我把验证独立出来进行配置验证,参考了common-validator,分为简单的验证(如类型长度最大值...),列表验证,还有DB中是否存在...这些都实现一个Validator接口。不知楼主有什么更好的办法?
2. 你从Excel读取数据到Bean(Dto)中的时候,不知道你有没有碰到,我是用POI读的,它读出来就那几种格式,而且只要Cell中全是数字,他就默认认为是Number型,整数也给你带上小数点,日期他默认是的也是Number型,这点有点麻烦。我做的时候是根据Dto中对应的成员类型把读出的数据进行相应的转换,这些类型转换也写了一个Converter接口,当然也可以直接用common包。
3. 既然这些数据是在Excel中写入或者从别的DB导入进去的,就难免有错误,而且这些错误不能以Exception直接抛出,必须生成一个txt或者Html文件格式的错误列表,指出错误的行号和列以及错误的详细信息,以便其修改再次上传。不知道您这个做了没有?如果做了可以写出来交流交流。我是验证的时候把所有错误全部记录下来(验证过程中有了错误就不转换数据只进行整个Excel数据的验证),然后把所有错误导出到Html。
4. 导出就简单了,但是我们多出了一个,可以导出到任意文件,如比较重要的是XML而且东航给出的十几个ATA XML Schema文件都是5 600kb的,看了很是头晕。不知道楼主对导出到XML有没有什么研究?

就这些吧,前天基本已经写完了,就剩导出到XML。


目前我还在项目中,功能已经做了很多改进和加强。
1、验证的功能我在下一个版本中已经做了加强。格式为dateType="Date yyyy-MM-dd"。
 只要单元格内是日期,能按给定的格式转换都是可以通过的。
 在jxl中单元格主要设计是:字符串,数字,日期格式。
2、像男(F) 女(M)代码之类的互像转换可以在组件中实现,
  Excel中存储的是男,而实际数据库存储时需要的是 F .见:

  Map map = new HashMap();
  map.put("deptNo", "1");
  map.put("bgqx永久", "Y");

 而像部门名称这种非标准代码表的验证,我想还是把他交给程序员来处理比较好。

 说明:功能上加入了,错误数据的回写功能,就是用户上传要导入的Excel文件,
  把正确的数据导入数据库中,出现错误行数据保留在Excel中,回传给用户,并做错误说明。
 
3、导出已经实现EXCEL格式,XML格式导出转未实现。
16 楼 myyate 2008-01-10  
楼主,看了你的代码不错,比我简洁多了。
我最近也写了类似的基础包,做一个通用程序,在web系统中把查询的数据导出到Excel和把上传过来的Excel数据导入DB。也是通过类似的XML配置Excel列和Dto(临时存放)成员对应。
我提几点与你交流一下:
1,既然你这个是要导入到DB中,就要有验证,我看你代码的验证主要是根据property元素里设置类似dataType、maxLength...来限制的,这样验证功能有限,比如还有某些列他的值是一些固定的值、日期必须符合yyyy-MM-dd...;还有比如你的部门,在Excel中用户她选择一些具体的部门名称,而不是编号之类,这个时候也需要验证这个部门名称是否合法?这些您是如何验证的?我把验证独立出来进行配置验证,参考了common-validator,分为简单的验证(如类型长度最大值...),列表验证,还有DB中是否存在...这些都实现一个Validator接口。不知楼主有什么更好的办法?
2. 你从Excel读取数据到Bean(Dto)中的时候,不知道你有没有碰到,我是用POI读的,它读出来就那几种格式,而且只要Cell中全是数字,他就默认认为是Number型,整数也给你带上小数点,日期他默认是的也是Number型,这点有点麻烦。我做的时候是根据Dto中对应的成员类型把读出的数据进行相应的转换,这些类型转换也写了一个Converter接口,当然也可以直接用common包。
3. 既然这些数据是在Excel中写入或者从别的DB导入进去的,就难免有错误,而且这些错误不能以Exception直接抛出,必须生成一个txt或者Html文件格式的错误列表,指出错误的行号和列以及错误的详细信息,以便其修改再次上传。不知道您这个做了没有?如果做了可以写出来交流交流。我是验证的时候把所有错误全部记录下来(验证过程中有了错误就不转换数据只进行整个Excel数据的验证),然后把所有错误导出到Html。
4. 导出就简单了,但是我们多出了一个,可以导出到任意文件,如比较重要的是XML而且东航给出的十几个ATA XML Schema文件都是5 600kb的,看了很是头晕。不知道楼主对导出到XML有没有什么研究?

就这些吧,前天基本已经写完了,就剩导出到XML。
15 楼 nanyjm 2008-01-08  
commons-lang-2.0.jar
commons-logging.jar
dom4j-1.6.jar
jxl.jar
log4j-1.2.8.jar
spring.jar
14 楼 afacd 2007-12-25  
建议楼主lib加一下所需jar清单

附件汇进来一堆错误,很难测试跑看看,还有少一些东西在,谢谢
13 楼 downpour 2007-12-12  
Java有个CSV的读取组件,可以应对多数的Excel导入工作,至于那些复杂的单元格合并等动能,就算是XML,也需要很复杂的定义,不妨直接操作。
12 楼 nanyjm 2007-12-12  
已经在增加新的功能,可支持整列,整行合并,一列中的多行合并。
如果合并的太多,且完全没有规律,也不太好办。
11 楼 ahau205109 2007-12-12  
can't control
10 楼 coder1982 2007-12-12  
问题是有些EXCEL文档 的格子是 不规律的
比如遇到单元格是合并的 那如何判断?
9 楼 xiaoych 2007-12-06  
不好意思,是 POI 不是POL
8 楼 xiaoych 2007-12-06  
apache 的 pol 好像也可以实现类似的功能。
7 楼 shy_1119 2007-12-06  
恩 应该研究一下
6 楼 nanyjm 2007-12-05  
pandaprince 写道

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



XML配置javaBean属性和EXCEL各列的映射关系,别走弯路。
一些新功能正在开发中。
5 楼 pandaprince 2007-12-05  
这个组件的设计思想还是很清楚的。
XML配置数据库字段和EXCEL各列的映射关系,
ExcelToModel通过JXL解析文件,根据配置每行生成JAVABEAN
遍历得到list

谢谢楼主,晚上回去试试
4 楼 nanyjm 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";
}
3 楼 nanyjm 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");


2 楼 godson_2003 2007-12-01  
有个问题不明白:
column :指excel没有表头名称时,可以对应所排的列号 是啥意思?

Excel文件:
部门名称 部门编号 发文简称 排序 操作结果 (没有这一行?)
总部 A001 永久 2 00000
分部 A002 长期 3 111111
分部 A003 长期 5

相关推荐

    基于NPOI的强类型Excel导入导出组件

    本项目是基于NPOI实现的一个强类型Excel导入导出组件,旨在简化开发者的工作流程,提高代码的可维护性和可读性。 NPOI的核心功能在于对Excel文件的读写操作。通过NPOI,我们可以创建新的Excel工作簿,添加工作表,...

    excel导入导出组件(java)

    这是我设计的excel导入导出组件,使用java 编写,通过xml文件的配置,来设置excel到java bean的映射。关键(配置)文件:ExcelModeMappingl.xml。 之前一直为excel的导入导出烦恼,每写一次都感觉是“重复造轮子”,...

    atiexcel-一个EXCEL导入导出组件

    **atiexcel** 是一款专为开发者设计的EXCEL导入导出组件,它简化了在应用程序中处理Excel数据的工作流程,提供了高效且灵活的接口来读取、写入和操作Excel文件。这款组件对于那些需要频繁与Excel交互的业务系统特别...

    excel导入导出通用组件

    这是一个利用poi封装的excel导入导出通用组件,详细用法请访问:http://fuyangrong.top/2018/01/29/excel导入导出通用组件/

    导入导出组件.rar

    "导入导出组件.rar"可能是一个包含Java库或者代码示例的压缩包,旨在帮助开发者实现Excel文件的数据交互。以下将详细讲解Java中进行Excel导入和导出的关键知识点: 1. **Java POI库**:Java POI是Apache软件基金会...

    java_poi实现excel导入导出

    Java POI 实现 Excel 导入导出 Java POI 是一个流行的 Java 库,用于处理 Microsoft Office 文件格式,包括 Excel 文件。在本文中,我们将详细介绍如何使用 Java POI 实现 Excel 导入导出功能。 1. 什么是 Java ...

    易语言EXCEL快速导入导出

    本示例将详细介绍如何利用易语言进行EXCEL快速导入导出的操作。 首先,我们需要了解易语言中与Excel相关的基础组件和函数。易语言提供了一个名为“通用数据访问组件”的模块,其中包含了读取和写入Excel文件所需的...

    Warship+NPOI导入导出组件(源代码+示例)

    1.Warship定位:Warship是一款基于NPOI的优秀的Excel导入导出组件,基于实体、特性、注入、多线程、IOC实现Excel的导入和导出,是一款使用方便、扩展性强、性能优良的组件,开发者不需要关注如何操作NPOI,只需要对...

    易语言EXCEL数据导入导出

    首先,我们要理解易语言中的“EXCEL数据导入导出”涉及的主要知识点。易语言提供了与Microsoft Excel交互的API接口或库,如COM组件,允许程序员通过调用Excel对象模型的方法来操作Excel文件。在易语言中,我们可以...

    J2EE项目开发Excel导入导出操作组件源代码(附带说明文档)

    总之,这个J2EE项目开发的Excel导入导出组件利用了Java的Apache POI库,实现了高效且灵活的Excel数据处理。开发者可以通过学习和使用这个组件,快速地在自己的项目中实现Excel数据的导入导出功能,提升开发效率,...

    J2EE项目开发Excel导入导出操作组件源代码(附带说明文档).rar

    本组件专注于解决这一问题,提供了一套完整的J2EE项目开发中进行Excel导入导出的解决方案。以下是关于这个组件的详细知识点: 1. **Excel文件格式**: - Excel文件主要基于两种格式:`.xls`(老版本,Excel 97-...

    一个通用从数据库导出excel、excel导入数据库组件所用到的jar包

    标题中的“一个通用从数据库导出excel、excel导入数据库组件所用到的jar包”指的是一个Java开发的工具,主要用于数据的导入导出操作。这个工具可以方便地将数据库中的数据导出为Excel格式,同时也可以将Excel文件中...

    POI实现Excel导入导出并附带加载进度条

    总之,这个项目是一个完整的Java解决方案,用于处理Excel文件的导入导出,同时具备用户友好的进度条显示。它利用了Apache POI的强大功能,结合maven的依赖管理,以及可能的GUI组件,提供了高效且直观的数据操作体验...

    C# Excel 导入导出

    Excel导入导出是常见的需求,例如数据处理、报表生成和数据分析等。本篇文章将详细探讨C#如何实现Excel的导入导出功能。 首先,我们需要知道在C#中操作Excel有两种主要方式:一是使用Microsoft.Office.Interop....

    J2EE项目开发Excel导入导出操作组件源代码

    通过这个J2EE项目开发的Excel导入导出操作组件源代码,开发者可以获得一个完整的解决方案,学习如何在J2EE环境中有效地处理Excel数据。同时,源代码和说明文档的结合,也为自定义和扩展功能提供了便利。

    Struts2 Excel导入导出数据

    在Struts2中,要实现Excel导入导出,我们需要以下组件: 1. **Apache POI库**:这是一个用于读写Microsoft Office格式文件的Java库,包括Excel。我们可以用它来创建、修改和读取Excel文件。 2. **Struts2 Action**...

    文件读写 Excel导入导出

    本文将深入探讨Excel文件的导入导出以及File读写操作,适用于各种版本的Excel。 首先,让我们了解一下Excel文件的导入与导出。在编程环境中,我们经常需要将数据从Excel文件加载到程序中,或者将程序处理后的结果...

    易语言excel导出导入模块

    总结来说,易语言excel导出导入模块提供了在易语言环境中便捷处理Excel数据的工具,对于需要处理大量结构化数据的程序开发,这个模块是一个非常实用的组件。通过对源码的学习和实践,开发者可以提升在数据处理方面的...

    excel导入导出资源引擎

    综合以上,"Excel导入导出资源引擎"是企业级应用中一个重要的组件,它使得在无Office环境的情况下也能高效、准确地处理Excel数据,提升了系统的灵活性和效率。通过深入理解并掌握其工作原理和使用方法,我们可以更好...

    Springboot+Poi实现Excel的导入导出

    本项目结合了Spring Boot、MyBatis、Apache POI和MySQL,实现了Excel数据的导入导出功能,这对于数据处理和分析尤其有用。下面我们将深入探讨这些技术及其在项目中的应用。 首先,Spring Boot以其“约定优于配置”...

Global site tag (gtag.js) - Google Analytics