功能概述

Excel2HtmlTable的主要功能就是把Excel的内容以表格的方式,展现在页面中。
Excel的多个Sheet对应页面的多个Tab选项卡。
转换算法的难点在于,如何处理行列合并,将Excel的行列合并模型转换成Html表格的行列合并模型。

背景故事

因实际需要,需要将Excel展现在Web界面中。

最初,想在网上找开源的东东,结果没有1个是想要的。有的特别复杂,有的只能在Windows平台,需要闭源的dll,最终还是得靠自己。

人不逼迫自己,真是想偷懒,不能出成果。

要是不是自己实现一次,根本不能发现和解决一系列问题。

最重要的经验就是:要努力克服自己的畏难情绪,不能怕麻烦。

CSDN下载地址(免积分)http://download.csdn.net/download/fansunion/6352759

相关截图

下载包内容

Excel2HtmlTable.zip:项目源码,1个完整的Eclipse项目,直接导入,Tomcat需要7.0。

Excel2HtmlTable效果图.gif:Excel模版对应的Html表格

Excel模版.gif:Excel模版内容

项目结构.gif:项目的结构

包和类说明

程序包 cn.fansunion.excel2html

ExcelToHtmlTable
把Excel(XSSFWorkbook)转换成Html的Table。
LoadReport Servlet,跳转到报表展示页面
QueryReport
响应前端AJax请求,查询Excel报表,转化为Html-Table格式的报表。

程序包 cn.fansunion.excel2html.model

说明
Col
表格的列。
DisplayDataModel
展示界面用到的数据模型。
Row
表格的行。
Table
展示Html用的表格,一个表格由多个行组成。
TableModel
Html表格模型,封装了一个Html表格的一些属性。

程序包 cn.fansunion.excel2html.util

 
说明
JsonUtils
JSON工具类。
ResponseUtils
HTTP响应常用代码封装。
TemplateLoader
Excel模版加载器。
TemplatePropertyReader
属性读取器,读取配置文件属性。

项目设计和实现思路

启动项目,进入主页,点击链接,进入报表展示页。

报表生成流程

 // 获得模版
XSSFWorkbook dataWorkbook = getTemplateWorkbook(); // 构造展示模型数据
List<TableModel> tableModelList = buildTableModelList(dataWorkbook); //构造最终展示需要的数据模型
DisplayDataModel model = new DisplayDataModel();
model.setTableModelList(tableModelList); //构造和发送JSON格式的数据
String beanToJSON = JsonUtils.beanToJSON(model);
ResponseUtils.setResponseHeaders(response);
ResponseUtils.sendJSONData(response, beanToJSON); // 获得Excel模版
private XSSFWorkbook getTemplateWorkbook() throws FileNotFoundException,
IOException, InvalidFormatException {
XSSFWorkbook workbook = TemplateLoader.buildSimpleWorkbook();
return workbook;
} // 构造数据模型,在界面展示
private List<TableModel> buildTableModelList(XSSFWorkbook dataWorkbook) {
ExcelToHtmlTable excelToHtmlTable = new ExcelToHtmlTable(dataWorkbook);
//init方法的思路,就是遍历Excel的每一个sheet、每一行、每一列,根据Excel的行列合并结构生成Html对应的行列合并结构
excelToHtmlTable.init();
List<TableModel> tableModelList = excelToHtmlTable.getTableModelList();
return tableModelList;
}

更多信息请参考项目源码。

特别说明

如果没有详细的注释,代码很难维护的。

主要是很多代码是处理Excel单元格的null和空字符串等,每一种数据类型,每一种情况,都需要很好地处理。

测试的时候,需要很多种不同风格内容的Excel。

另外,这个项目是我花了4个小时的时间,单独从项目中抽取出来的,有些地方的命名可能有点奇怪。

如果想完全理解这个算法,除了自己认真研究源码外,没有其它的方法,不要指望作者本人一点点地讲解清晰。

下一步计划

将这个算法,封装成为一个单独的Jar包。

今后,如果有需要,直接加入jar包,调用API就好了。

一个开发人员在实践中,一定要逐步积累可复用的方法、类、组件,如果每次都重新编码,实现重复的功能,只能当码农。

如何运行本程序

上次写了Struts2SpringHibernate整合示例,一个HelloWorld版的在线书店(项目源码+详尽注释+单元测试)

http://blog.csdn.net/fansunion/article/details/12215233

有同学遇到了问题,有的不知道怎么运行,所以这次需要说明一下。

这个项目的源码是一个 Eclipse项目,需要导入到Eclipse的工作空间中。

添加Server,Tomcat7,启动后,访问主页(默认是index.jsp),然后点击 主页上的链接 就可以看到 报表了。

答读者问

sdsada8小时前
1楼
lz难道不知道excel有webapp吗?另外,找个wysiwyg的html编辑器,直接粘贴复制可行吗? 
 
答:

项目原来用的是Excel,查看报表,首先需要下载下来。

现在要求在Web界面中展示。

Excel里有大量的公式,先把数据从NoSQL数据库填充到Excel,然后让Excel自动计算公式,最后把Excel展现到Web界面中。

原文参见:http://FansUnion.cn/articles/2634

ExcelToHtmlTable转换算法:将Excel转换成Html表格并展示(项目源码+详细注释+项目截图)的更多相关文章

  1. 【JAVA-JDT-AST】Java抽象语法树的构建、遍历及转成dot格式(附Github源码)

    Background: 最近为了重现tree-based clone detection的论文:L. Jiang, G. Misherghi, Z. Su, and S. Glondu. Deckar ...

  2. Asp.net实现直接在浏览器预览Word、Excel、PDF、Txt文件(附源码)

    功能说明 输入文件路径,在浏览器输出文件预览信息,经测试极速(Chrome).IE9.Firefox通过 分类文件及代码说明  DemoFiles 存放可测试文件 Default.aspx  启动页 ...

  3. 机器学习:IB1算法的weka源码详细解析(1NN)

    机器学习的1NN最近邻算法,在weka里叫IB1,是因为Instance Base  1 ,也就是只基于一个最近邻的实例的惰性学习算法. 下面总结一下,weka中对IB1源码的学习总结. 首先需要把 ...

  4. ASP.NET 之 常用类、方法的超级总结,并包含动态的EXCEL导入导出功能,奉上类库源码

    实用类:UtilityClass 包含如下方法 判断对象是否为空或NULL,如果是空或NULL返回true,否则返回false 验证手机号是否正确 13,15,18 验证邮箱 验证网址 MD5加密,返 ...

  5. Java开源生鲜电商平台-订单抽成模块的设计与架构(源码可下载)

    Java开源生鲜电商平台-订单抽成模块的设计与架构(源码可下载) 说明:订单抽成指的是向卖家收取相应的信息服务费.(目前市场上有两种抽成方式,一种是按照总额的抽成比率,另外一种是按照订单明细的抽成比率 ...

  6. 【转】asp.net(c#)加密解密算法之sha1、md5、des、aes实现源码详解

    原文地址:http://docode.top/Article/Detail/10003 目录: 1..Net(C#)平台下Des加密解密源代码 2..Net(C#)平台下Aes加密解密源代码 3..N ...

  7. 【PHP版】火星坐标系 (GCJ-02) 与百度坐标系 (BD-09ll)转换算法

    首先感谢java版作者@宋宋宋伟,java版我是看http://blog.csdn.net/coolypf/article/details/8569813 然后根据java代码修改成了php代码. & ...

  8. HttpRunner3源码阅读:4. loader项目路径加载,用例文件转换、方法字典生成

    loader.py 这个文件中主要是对yaml,json用例加载转换成用例处理, 预置函数加载成方法字典,路径加载等 可用资料 [importlib]. https://docs.python.org ...

  9. XAF Excel数据导入模块使用说明与源码

    我实现了XAF项目中Excel数据的导入,使用Devexpress 新出的spreadsheet控件,可能也不新了吧:D 好,先看一下效果图:下图是Web版本的. 下面是win版: 功能说明: 支持从 ...

随机推荐

  1. Centos与Ubuntu命令

    1.虽然Centos与Ubuntu都是linux的内核,但使用命令还是有所差别 2.如在Centos中跟新插件用的是:yum -y   (yum后面有一个空格) 在Ubuntu中跟新插件用的是:apt ...

  2. POJ 1320

    作弊了--!该题可以通过因式分解得到一个佩尔方程....要不是学着这章,估计想不到.. 得到x1,y1后,就直接代入递推式递推了 x[n]=x[n-1]*x[1]+d*y[n-1]*y[1] y[n] ...

  3. Unity里包裹Debug,且不影响Debug的重定向

    Debug.Log, Debug.LogWarning, Debug.LogError在project中常常须要再包裹一层.做些定制.也方便开关Log.但有一个问题时.当用一个类将Debug包裹起来后 ...

  4. SVN打tag

          SVN打tag是一个非经常常使用的功能,要谈打tag,还得从SVN官方推荐的文件夹结构说起.SVN官方推荐在一个版本号库的根文件夹下先建立trunk.branches.tags这三个文件夹 ...

  5. Android广播机制分析

    1.1. 广播简单介绍         Android 广播与生活中的广播概念不同,它是指系统中产生事件后的通知. Android 广播不关心接收者是否收到处理或者怎样处理广播,能够说是一种单向的通知 ...

  6. Linux体验之旅(一)——制作U启,安装rhel-server-6.3

    U启制作: 双击UltraISO: 点击文件→打开: 选择rhel-server6.3 点击启动→选择写入硬盘映像 最后选择格式化优盘→写入→完毕 注意:启动盘制作完毕后一定记得将rhel-serve ...

  7. SQL从头開始

    SQL 分为两个部分:数据操作语言 (DML) 和 数据定义语言 (DDL) 查询和更新指令构成了 SQL 的 DML 部分: SELECT - 从数据库表中获取数据 UPDATE - 更新数据库表中 ...

  8. iOS 权限判断 跳转对应设置界面

    相机权限 1.1 使用说明 在合适的地方导入#import <AVFoundation/AVFoundation.h> 使用AVAuthorizationStatus类获取当前权限状态 在 ...

  9. IIS之虚拟目录学习

    从刚实习开始就了解到虚拟目录这个词,但是一直没去研究过什么意思,而且也没实际用过.一晃两年过去了,今天正好趁休息,补补脑学习下. 通过百度了解到,虚拟目录创建的目的是为了应对磁盘容量爆满,部署的网站不 ...

  10. 解决问题方法:没有设置对象,app.Config没有配置