`
buliedian
  • 浏览: 1237132 次
  • 性别: Icon_minigender_2
  • 来自: 北京
文章分类
社区版块
存档分类
最新评论

解析和生成Excel报表方法汇总(转)

阅读更多
昨天在医院检查身体时,一个朋友打过来电话,咨询EXCEL报表开发都有哪些方法,他们要上一个有200多个不同格式Excel报表的项目,虽然在医院做全身检查中,我还是给他提供了几点建议。在这里我顺便总结下.NET平台下Excel报表开发的各种方法吧,供大家参考。
其实不仅仅是.NET平台,其他的任务开发平台和EXCEL报表交互,最终都会面临2个问题:如何解析EXCEL报表和如何生成EXCEL报表。
下面就以这2个问题为出发点,来探讨一下各种方法。
方法一:通过Excel对象模型(COM接口)解析和生成EXCEL报表。
.NET访问Office对象模型是借鉴于VBA的,VBA是整合到所有Office应用程序中的一个简单开发环境,每个Office程序都带有丰富的对象模型并通过COM技术实现对这些模型的访问。但遗憾的的是VBA有一定的局限性,VBA的开发环境过于简单,功能有限,VBA将代码嵌入到每个自定义文档中,这就使得修复漏洞和更新解决方案变得困难。微软为了让老的VBA程序员过渡到.NET平台继续开发Office程序,就进行技术更新,产生一种称为COM interop.NET技术与.NET中的Office对象模型进行交互。本质上所有的Office对象模型都是用非托管代码编写的(比如CC++),并提供COM接口。为了在托管代码(C#VB.NET)中与这些接口进行通信,必须使用封装器,通过它来实现托段代码与Office的非托管COM接口之间的协同工作。该封装器是一系列的.NET类,它有一个更好的名字叫Office主互调程序集(PIA:Primary Interop Assemblies)PIA便是.NET用于和Office交互的托管程序集。如下图:

这种方法能解析和生成EXCEL文档,功能强大,可以读写到任意单元格,生成单元格样式,合并单元格,支持图表等等。可以在.NET任何项目中使用,但会面临释放托管资源的问题。很多朋友认为这种方法必须要装EXCEL程序(Office),其实只需要安装PIA就可以了。PIA会在完全安装Office时自动安装,也可以在安装Office的向导中选择。但有个更好的方法是单独安装和分发PIA,微软想到了这一点,你可以通过下面的链接单独获取PIA的分发包。
Office 2003 Update: Redistributable Primary Interop Assemblies
http://www.microsoft.com/downloads/details.aspx?FamilyID=3c9a983a-ac14-4125-8ba0-d36d67e0f4ad&DisplayLang=en
2007 Microsoft Office System Update: Redistributable Primary Interop Assemblies
http://www.microsoft.com/downloads/details.aspx?familyid=59DAEBAA-BED4-4282-A28C-B864D8BFA513&displaylang=en
Office PIA会被安装到GAC目录,GAC位于Windows目下的Assembly子目录。
如果要使用PIA必须要先在项目中添加引用,如下图:
Excel 2007PIA12.0,如上图。Excel 2003PIA的是11.0
方法二:通过OLEDb解析Excel报表。
OleDb解析Excel报表,本质上是通过OleDb驱动完成的,此时可以把Excel当做一张数据库表来读取,Excel 2003用的驱动是Microsoft.Jet.OLEDB.4.0 Excel 2007用的驱动是Microsoft.Ace.OleDb.12.0,OleDb在解析Excel功能上比较简单,实际项目中往往运用此方法来获取Excel数据,如下图:
方法三:通过Access对象模型(COM接口)生成EXCEL报表。
此方法同方法一技术上类似,但是此时引用的PIA不是Excel的,而是Access的。如下图:
Access 2007PIA12.0,如上图。Access 2003PIA的是11.0
通过Access PIA,可以把Access 数据库中的表完美快速的生成到Excel工作薄中,可以同时生成多个工作表,速度非常之快,日期类型,货币类型,长格式数值,都会自动转成文本,不存在’#’或科学计数的问题。
方法四:通过开放Open Xml生成Excel报表
这种方法是基于Office Open Xml的,服务器和客户端都不需要安装Excel,可以在.NET任何项目中使用,开发难度高,但部署成本比较低。在格式方面,Open Xml对单元格样式控制能力很强,可以生成各种格式的单元,生成Excel的效率也非常高。
下图的中2个标注的地方都运用了这种技术生成Excel报表。
方法五:通过水晶报表和微软报表生成Excel报表
水晶报表功能强大,能生成复杂Excel报表,但是它是收费的。
而微软报表(Microsoft RepoertViewer)功能强大,本质上是微软借鉴水晶报表开发的,所以和水晶报表没什么两样,而且直接集成到了Visual Studio中。微软报表可以在.NET任何项目中使用,不仅可以生成EXCEL报表,还可以生成PDF等。下图是微软报表的一个应用,这个报表默认是横向打印:
说到这,不得不提微软数据库系统中的SSRS,这个报表服务引擎非常强大,不仅包含创建报表的功能,还包括管理和访问报表的功能,这是一个真正的企业级报表平台。
方法六:通过构建HTML标签向客户端生成Excel报表。
这种方法,在asp.net项目中很常见,尤其是在生成中国式的报表项目中非常常用。这种方法首先是构造HTML标签,生成指定的格式,填充数据,最后发送客户端,保存成Excel报表格式。当然这种发放就更不需要安装Excel程序了。
方法七:通过构造CVS格式生成EXCEL报表。
这种方法只能生成无格式的Excel报表,不需要安装Excel程序。
方法八:通过开源软件解析和生成Excel报表(基于BIFF)。
开源项目中有2个解析和生成Excel文件的精品:KoograMyxls,他们都是基于BINARY FILE FORMAT(BIFF)Excel文件结构形式开发的。运用这个开源项目进行解析和生成Excel报表都不需要安装Office,部署方便。
Koogra用于解析Excel文件。Myxls用于生成Excel文件。
先总结这8种方法,但是实际上还有其他的方法,比如强大的Active-x报表等等。

本文出自 “李涛的技术专栏” 博客,出处http://terryli.blog.51cto.com/704315/372820

分享到:
评论

相关推荐

    C#ASP.NET网络进销存管理系统源码数据库 SQL2008源码类型 WebForm

    ASP.NET网络进销存管理系统源码 内含一些新技术的使用,使用的是VS .NET 2008平台采用标准的三层架构设计,采用流行的AJAX技术 使操作更加流畅,统计报表使用FLASH插件美观大方专业。适合二次开发类似项目使用,可以节省您 开发项目周期,源码统计报表部分需要自己将正常功能注释掉的源码手工取消掉注释。这是我在调试程 序时留下的。也是上传源码前的疏忽。 您下载后可以用VS2008直接打开将注释取消掉即可正常使用。 技术特点:1、采用目前最流行的.net技术实现。2、采用B/S架构,三层无限量客户端。 3、配合SQLServer2005数据库支持 4、可实现跨越地域和城市间的系统应用。 5、二级审批机制,简单快速准确。 6、销售功能手写AJAX无刷新,快速稳定。 7、统计报表采用Flash插件美观大方。8、模板式开发,能够快速进行二次开发。权限、程序页面、 基础资料部分通过后台数据库直接维护,可单独拿出继续开发其他系统 9、数据字典,模块架构图,登录页面和主页的logo图片 分别放在DOC PSD 文件夹中

    (源码)基于ZooKeeper的分布式服务管理系统.zip

    # 基于ZooKeeper的分布式服务管理系统 ## 项目简介 本项目是一个基于ZooKeeper的分布式服务管理系统,旨在通过ZooKeeper的协调服务功能,实现分布式环境下的服务注册、发现、配置管理以及分布式锁等功能。项目涵盖了从ZooKeeper的基本操作到实际应用场景的实现,如分布式锁、商品秒杀等。 ## 项目的主要特性和功能 1. 服务注册与发现通过ZooKeeper实现服务的动态注册与发现,支持服务的动态上下线。 2. 分布式锁利用ZooKeeper的临时顺序节点特性,实现高效的分布式锁机制,避免传统锁机制中的“羊群效应”。 3. 统一配置管理通过ZooKeeper集中管理分布式系统的配置信息,实现配置的动态更新和实时同步。 4. 商品秒杀系统结合分布式锁和ZooKeeper的监听机制,实现高并发的商品秒杀功能,确保库存的一致性和操作的原子性。 ## 安装使用步骤 1. 环境准备

    23python3项目.zip

    23python3项目

    技术资料分享AL422B很好的技术资料.zip

    技术资料分享AL422B很好的技术资料.zip

    c语言俄罗斯方块.rar

    c语言俄罗斯方块

    【CPO栅格地图】基于matlab豪猪算法CPO栅格地图路径规划(目标函数:最短距离)【含Matlab源码 9152期】.mp4

    Matlab领域上传的视频均有对应的完整代码,皆可运行,亲测可用,适合小白; 1、代码压缩包内容 主函数:main.m; 调用函数:其他m文件;无需运行 运行结果效果图; 2、代码运行版本 Matlab 2019b;若运行有误,根据提示修改;若不会,私信博主; 3、运行操作步骤 步骤一:将所有文件放到Matlab的当前文件夹中; 步骤二:双击打开main.m文件; 步骤三:点击运行,等程序运行完得到结果; 4、仿真咨询 如需其他服务,可私信博主; 4.1 博客或资源的完整代码提供 4.2 期刊或参考文献复现 4.3 Matlab程序定制 4.4 科研合作

    delphi人才信息管理系统.zip

    delphi人才信息管理系统

    安卓巴士总结了近百个Android优秀开源项.zip

    安卓巴士总结了近百个Android优秀开源项

    MATLAB蒙特卡洛仿真计算投资组合的VaR(Value at Risk )

    1.程序功能说明: MATLAB蒙特卡洛仿真计算投资组合的VaR(Value at Risk ) 根据协方差矩阵等参数先计算涨期权和看跌期权的价格,再采用蒙特卡洛模拟法计算该投资组合的VaR。 2.代码说明:注释清晰,参数和变量说明清晰,方便更改、方便初学者使用,模块化编程,方便替换目标函数。运行环境Windows7及以上操作系统,MATLAB2014a及以上版本。 3.适用专业:计算机、电子信息工程、数学、物理、机械工程、土木工程等专业的大学生、研究生毕业设计,各类专业的课程设计、海外留学生作业等。 4作者介绍:资深算法工程师, 从事Matlab、Python算法仿真工作15年,专业研究遗传算法、粒子群算法、蚁群算法、鲸鱼算法、狼群算法等. 有问题联系QQ: 1579325979

    SpringBoot - Async异步处理

    SpringBoot - Async异步处理

    完全退出程序的方法.zip

    完全退出程序的方法

    hutool工具操作excel表格的依赖jar包

    hutool.all操作excel的依赖包,一共18个jar包,懒得去排查包的可以直接下载直接导入使用;我用eclipse和ideal接导入外部jar包。亲测可用;如果工程里面有相同的jar包,保留版本号高的; commons-cli-1.0.jar commons-codec-1.15.jar commons-collections4-4.4.jar commons-compress-1.21.jar commons-io-2.11.0.jar commons-lang3-3.4.jar commons-logging-api-1.1.jar commons-math3-3.6.1.jar hutool-all-5.8.21.jar log4j-1.2.12.jar log4j-api-2.20.0.jar log4j-core-2.20.0.jar poi-5.2.3.jar poi-ooxml-5.2.3.jar ……

    (源码)基于Python的微信签到管理系统.zip

    # 基于Python的微信签到管理系统 ## 项目简介 本项目是一个基于Python的微信签到管理系统,旨在通过微信自动收集和管理学生的宿舍签到信息。系统通过微信的群聊功能,自动识别并记录符合特定格式的签到信息,并将其存储在Excel表格中。该系统特别适用于学校或组织需要定期收集学生签到信息的场景。 ## 项目的主要特性和功能 1. 自动签到信息收集系统能够自动检测微信中大于三人的群聊,识别并记录符合特定格式的签到信息。 2. 灵活的签到格式支持自定义签到格式,通过正则表达式匹配签到信息,确保信息的准确性和一致性。 3. 自动生成签到表格每周自动生成新的签到表格,并根据开学周数计算当前学期的周数。 4. 转发补录功能支持通过转发信息的方式补录错过的签到信息,提高信息的完整性。 5. 路径和模板配置允许用户自定义签到表格的存储路径和模板信息,方便管理和维护。 ## 安装使用步骤 ### 1. 环境搭建

    (源码)基于Arduino和OpenWeatherMap的天气LED显示系统.zip

    # 基于Arduino和OpenWeatherMap的天气LED显示系统 ## 项目简介 此项目是一个基于天气数据的LED显示系统,主要用于展示当前的天气状况。它使用了WiFi连接的Arduino和LED灯带,通过OpenWeatherMap提供的API获取天气数据。项目旨在提高技术技能和软技能模块的学习成果。 ## 项目的主要特性和功能 ### 天气数据的展示 实时天气展示系统可以展示不同的天气状况,如晴朗、多云、降雨、雷电、雾等。 地点设置用户可以通过Blynk应用设置想要展示的地点,并实时获取该地点的天气数据。 更新间隔设置用户还可以设置数据更新的时间间隔。 ### 动画展示功能 天气模拟动画系统具有动画展示功能,用户可以选择不同的动画模式,如天气模拟动画。 LED颜色变换支持单个LED灯的颜色变换以及色彩淡入淡出动画等。 自动切换动画模式可以手动选择或通过定时设置自动切换。 ## 安装和使用步骤

    将jar文件转换为exe

    将jar文件转换为exe

    trumtime安装所需的全部资源以及步骤

    tdm64-gcc-9.2.0是一个编译器,如果大家在安装truetime运行中无法直接下载官方的编译器,就参考配置方法文档用这个编译器 大家需要首先安装vc++,可参考安装VScode 2019 版本

    SAE AS5756C-2021 中文.pdf

    SAE AS5756C-2021 中文.pdf

    c语言实现水波纹显示效果.rar

    c语言实现水波纹显示效果

    基于C语言的winform界面火车票订票系统项目资源.zip

    基于C语言的winform界面火车票订票系统项目资源

    2024年企业竞争模拟大赛河南大学校赛的通知(1) (1).pdf

    2024年企业竞争模拟大赛河南大学校赛的通知(1) (1).pdf

Global site tag (gtag.js) - Google Analytics