1:前言

看过我文章的网友们都知道,通常前言都是我用来打酱油扯点闲情的。

自从写了上面一篇文章之后,领导就找我谈话了,怕我有什么想不开。

所以上一篇的(下)篇,目前先不出来了,哪天我异地二次回忆的时候,再分享分享。

话说最近外面IT行情飞涨还咋的,人都飞哪去了呢,听说各地的军情都进入紧急状态了。

回归下正题,今天就抽点时间,写写技术文,和大伙分享一下近年在框架设计上的取的一些技术成果。

2:项目背景

在针对运营商(移动、联通、电信、铁塔)的信息类的系统中,由于相关的从业人员习惯于Excel的办公思维。

导致在做该类系统中时,Excel的导入导出功能,几乎成了每个有列表展示的页面上必备功能。

因此,有必要对Excel导入导出进行抽象并组件化设计,以至于后面占了整个开发框架中一个很牛B的位置。

而这一切的演进与进化,始于以下这越来越变态的需求:

3:从模板的指定方式看进化

阶段一:由开发方精心设计Excel模板

我们都知道,要把一批数据导进系统中,最基本的做法,就是约定好导入的模板,然后针对精心设计好的模板进行编码。

而客户则按格式填写好数据后,如无意外的就导入系统中了。

如此如此这般这般之后:

对于开发:会选择一种最简单开发的方式,尽量确保每个字段不需要特殊处理都和数据库对的上,不用做过多的额外代码编写。

对于客户:需要按指定的格式填写数据,需要花不少时间。

阶段二:Excel模板的格式由客户指定

后续的调研进展,客户要亲自指定模板中的列及格式。

如此如此这般这般之后:

对于开发:需要按指定的格式去开发,甚至可能缺少某些列,要做一些额外的查询或代码处理。

对于客户:可以简单的从其它办公的Excel中复制数据到模板,进行简单的修改后导入。

阶段三:从某系统导出Excel数据,要求能直接导入系统

客户越来越牛B了,认为搞模板这东西太复杂了,既然其它系统能导出来,直接弄过去就得了。

如此如此这般这般之后:

对于开发:由于某系统导出的Excel数据,乱七杂八,用API读出来的数据,不符常规则,要做N多兼容处理,工作量翻了N翻。

对于客户:从其它系统导出Excel数据,直接导进系统,真泥玛的省心。

阶段四:要求系统中导出的Excel数据列表,修改数据后可以直接导入系统

客户已经超越牛A与C之间了,哥穿越七八张表,用了N个Case和GroupBy及N层子嵌套才弄出来的报表数据,你要给导回基础表去?

如此如此这般这般之后:

对于开发:45度仰角呼唤你爷。

对于客户:我只要某几个字段改了能回去就行。

4:从模板的复杂度看进化

Stage One:单表导入

好简单的说,使用 CYQ.Data 框架(好久没在文章中介绍了,历经几年低调的发展,有机会再写文)中MDataTable的批量功能,一行代码就完事了。

Stage Two:多表导入

麻烦开始了,两张表就算了,可是你来2,3,4,5,6,7表,一个导入要关联这么多表,还得理解业务,还要分拆一对N关系,一个导入要整好几天。

如果回头客户说改模板,心里瞬时多了几草泥马穿过。。。

Stage Three:要求导出和导入的Excel都有多级表头

又麻烦了,合并的单元头、卧槽还有同名的列头,难道要写死指定第N行的列头就A表名字,N+N行的列头是B表的名字?

如果模板增加字段,换了位置, 心里莫名又多了几只草泥马越过。。。。

Stage Four:表头和数据藏在中间,要求能自动忽略上下左的垃圾数据

模板的上面十几行,是一大堆没用的数据,模板的左边和下面,是一些填写的说明(而这些,是其它系统的数据,跟我们做的系统有毛关系啊,但客户就是这么牛B)

所以,又要增加处理,从第几行读数据,列头跨几个行,右边第N行是无效的,心里刹间又多了几只草泥马踩过。。。

Stage Five:多Sheet导入

模板增加一个分类列就可以搞定的事,客户打死也不要,非要一个分类一个Sheet,然后全部导入。

所以,你得按Sheet名称自动转换成分类名称,来处理这些事。

还有原来一个Sheet多表的一对N关系,要分拆到N个Sheet里去让你处理导入, 心里哗哗已无数只草泥马踏过。。。

5:总结:

在正常的需求阶段,理论上是应该引导用户规避掉一些不合理的设计,但现实有时候就是被客户牵着走。。。

因此,在面对如此这么复杂的场景和变态要求下,如果不设计一套智能组件,则开发成本和开发人员无疑将陷入无限的悲哀中。

好在,我在。

下一文,将与大伙分享Excel的组件化的设计方案

Excel导入导出的业务进化场景及组件化的设计方案(上)的更多相关文章

  1. Mego(04) - NET简单实现EXCEL导入导出

    前言 相信做过信息系统的朋友都会遇到EXCEL导入导出的相关开发,做过不少EXCEL导入导出后总结起来大致有如下几种方式实现: ADO.NET的OldDb或ODBC连接EXCEL使用DataTable ...

  2. TP5.0 excel 导入导出

    引第三方的phpexcel类库放到 ThinkPHP\Library\Vendor\demo下,自己建的文件夹demo 再将Excel.class放到ThinkPHP\Library\Org\clas ...

  3. Java基础学习总结(49)——Excel导入导出工具类

    在项目的pom文件中引入 <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifac ...

  4. 如何自动化你的Excel导入导出(Java)?

    GitHub | 中文 | English | 博客 为什么使用AutoExcel? Excel导入导出在软件开发中非常常见,只要你接触过开发,就一定会遇到.相信很多人会跟我一样选择用Apache P ...

  5. 基于EPPlus和NPOI实现的Excel导入导出

    基于EPPlus和NPOI实现的Excel导入导出 CollapseNav.Net.Tool.Excel(NuGet地址) 太长不看 导入 excel 文件流将会转为 ExcelTestDto 类型的 ...

  6. 基于 POI 封装 ExcelUtil 精简的 Excel 导入导出

    注 本文是使用 org.apache.poi 进行一次简单的封装,适用于大部分 excel 导入导出功能.过程中可能会用到反射,如若有对于性能有极致强迫症的同学,看看就好. 序 由于 poi 本身只是 ...

  7. 企业级自定义表单引擎解决方案(十六)--Excel导入导出

    Excel对于后端管理系统来说,永远都是绕不开的话题,开发Excel导入导出功能往往都比较麻烦,因为涉及到Excel导入模板制作.Excel表格数据与系统数据库表字段映射.Excel导入数据验证.验证 ...

  8. 利用反射实现通用的excel导入导出

    如果一个项目中存在多种信息的导入导出,为了简化代码,就需要用反射实现通用的excel导入导出 实例代码如下: 1.创建一个 Book类,并编写set和get方法 package com.bean; p ...

  9. 关于Excel导入导出的用例设计

    目前,为方便操作,很多系统都会增加批量导入导出的功能.文件导入导出一般格式都是excel.由于用户直接在excel在填写内容,无法控制填写的格 式,加上excel解析比较困难,所以一般涉及到excel ...

随机推荐

  1. 马氏距离(Mahalanobis distance)

    马氏距离(Mahalanobis distance)是由印度统计学家马哈拉诺比斯(P. C. Mahalanobis)提出的,表示数据的协方差距离.它是一种有效的计算两个未知样本集的相似度的方法.与欧 ...

  2. Java研发岗位面试归类A(附答案)

    题目来自http://www.codeceo.com/article/201-java-interview-qa.html,答案自己网上找的,如有疏漏,欢迎斧正.一起学习,共同进步. 一.Java基础 ...

  3. 2016-11-05实战-定义ssh服务的日志

    1.编辑/etc/rsyslog.conf 输入 local 0 .*     /var/log/sshd.log   #日志的保存路径 2.定义ssh服务的日志级别 编辑sshd服务的主配置文件:/ ...

  4. 图文介绍如何在Eclipse统计代码行数(转)

    使用Eclipse可以方便的统计工程或文件的代码行数,方法如下: 1.点击要统计的项目或许文件夹,在菜单栏点击Search,然后点击File... 2.选中正则表达式(Regular expressi ...

  5. maven权威指南学习笔记(四)—— maven生命周期(lifecycle)

    定义: 生命周期是包含在一个项目构建中的一系列有序的阶段 举个例子来说就是maven 对一个工程进行: 验证(validate) -- 编译源码(compile) -- 编译测试源码(test-com ...

  6. java中包的命令行(cmd)操作详解

    一.什么是包? 为了更好地组织类,防止在一个空间下出现类重名,Java提供了包机制.包是类的容器,用于分隔类名空间(类型于C++中的命名空间).如果没有指定包名,所有的示例都属于一个默认的无名包(又称 ...

  7. 安装ganglia

    安装ganglia 1.默认已经配置好相关的主机名和Ip地址映射关系 2.默认已经安装好ssh密码登陆 3.默认已经配置好yum源和相关网络配置(如hosts 可在墙外) 4.服务器端安装(除了yum ...

  8. gitbook安装与使用之windows下搭建gitbook平台

    最近需要在GitBook中去阅读电子书 安装nodejs cnpm安装gitbook 解压书籍文件,并cd到书籍文件目录 gitbook serve 浏览器访问localhost:4000 先在win ...

  9. mac apache 2.4的配置

    开启vhost 文件 命令行输入 vim /etc/apache2/httpd.conf 找到把前边的# include /private/etc/apache2/extra/httpd-vhost. ...

  10. Curator leader 选举(一)

    要想使用Leader选举功能,需要添加recipes包,可以在maven中添加如下依赖: <dependency> <groupId>org.apache.curator< ...