ExcelUtils简单上手

不过对于数据多的情况,很耗性能,还是老老实实用POI吧,哎

其实ExcelUtils的User's Guide已经相当清楚了,我就权当体验中文记录一下了。

ExcelUtils代表着一类的报表生成工具,他使用报表本身作为模板。对于它,只能处理Excel文件,它以Excel文件为模板,在其上加以自己的定义语言,简单通俗!

官方主页:http://excelutils.sourceforge.net/Overview.html


1. 首先在项目classpath加入以下五个jar包:
  • excelutils.jar
  • poi-2.5.1.jar
  • commons-logging.jar
  • commons-digester.jar
  • commons-beanutils.jar
2. 建立一个Excel模板(demo.xls),如下图(因为对Excel使用等同白痴,这里纠结了很久,直接贴图出来希望对和我一样的朋友有帮助)



3. 写程序测试了,官方的user's guide给的是web例子,我就直接写个main方法测试先了:
  1. public static void main(String[] args) {
  2. Model model = new Model("aaa", "bbb", 123.234);

  3. List details = new ArrayList();
  4. details.add(new Model("user1", "kong", 1234.342));
  5. details.add(new Model("user2", "hello", 1224.342));
  6. details.add(new Model("user3", "world", 144.342));

  7. ExcelUtils.addValue("printDate", getCurrentDate("yyyy-MM-dd"));
  8. ExcelUtils.addValue("model", model);
  9. ExcelUtils.addValue("list", details);
  10. String config = "demo.xls";
  11. try {
  12. ExcelUtils.export(config, new FileOutputStream("demo2.xls"));
  13. } catch (FileNotFoundException ex) {
  14. System.out.println("文件路径找不到");
  15. } catch (ExcelException ex) {
  16. System.out.println(">>>>>>>>>>>> 错误:ExcelException");
  17. Logger.getLogger(TestExcelUtils.class.getName()).log(Level.SEVERE, null, ex);
  18. }
  19. }

  20. private static String getCurrentDate(String format) {
  21. SimpleDateFormat sdf = new SimpleDateFormat(format);
  22. return sdf.format(new Date());
  23. }
4. 直接运行main方法测试,结果如下图:


可以看到,利用ExcelUtils直接对已定义变量标签的模板进行写数据相当简单,避免了我自己用POI的许多麻烦,接下来就可以自己试着应用到web项目中了。


JXLS跟excelUtils都是excel的开源模板引擎,用于生成excel报表。

JXLS与excelUtils用法类似,详细参考,简单来说JXLS是Apache开发的,支持比较多,目前我也在也用JXLS

http://www.iteye.com/topic/75431

http://www.oschina.net/code/snippet_1158817_45773

官方:http://jxls.sourceforge.net/



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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值