论坛首页 Java企业应用论坛

Excel导入导出组件

浏览 31047 次
精华帖 (2) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
作者 正文
   发表时间:2007-12-12  
can't control
0 请登录后投票
   发表时间:2007-12-12  
已经在增加新的功能,可支持整列,整行合并,一列中的多行合并。
如果合并的太多,且完全没有规律,也不太好办。
0 请登录后投票
   发表时间:2007-12-12  
Java有个CSV的读取组件,可以应对多数的Excel导入工作,至于那些复杂的单元格合并等动能,就算是XML,也需要很复杂的定义,不妨直接操作。
0 请登录后投票
   发表时间:2007-12-25  
建议楼主lib加一下所需jar清单

附件汇进来一堆错误,很难测试跑看看,还有少一些东西在,谢谢
0 请登录后投票
   发表时间:2008-01-08  
commons-lang-2.0.jar
commons-logging.jar
dom4j-1.6.jar
jxl.jar
log4j-1.2.8.jar
spring.jar
0 请登录后投票
   发表时间: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。
0 请登录后投票
   发表时间: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格式导出转未实现。
0 请登录后投票
   发表时间:2008-01-13  
最好用poi对多语言支持比较好!!
0 请登录后投票
   发表时间:2008-01-13  
曾经使用泛型做的,一个通用的Excel和Javabean相互转换的东东。
写到Excel的时候很容易,读的时候可以考虑使用Spring的BeanWapper
和PropertyEditor来把字符串类型进行转换,转化成javabean。
0 请登录后投票
   发表时间:2008-10-31  
曾经在项目中也做了一个类似的excel导入功能。当时做得比较简单,excel列到VO的转换协议是直接写在excel标题中了。。没有你做的细致,感谢你的工作,值得参考
0 请登录后投票
论坛首页 Java企业应用版

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