[原创]C#通过引用Office Excel (2007) 组件实现对Excel文件的操作

简介:

对用应用软件来说,将报表转出为Excel文件,进行二次加工,或者根据Excel模版填充数据,是非常常用的。实现对Excel文件的操作,如将报表转出为Excel或根据已有的Excel模版进行填充,有很多方法,比如使用第三方组件,根据Open XML的标准,将WEB页面中的控件直接输出等等,还有一种方式就是引用Office Excel组件,直接由.NET程序调用。即在项目的“引用(References)”处直接引用Office的Excel组件,这时,系统自动会生成一个Microsoft.Office.Interop.Excel.dll的文件,此文件相当于.NET 托管代码与Office COM组件的一个接口(Interop)。

这样做有其优缺点,

优点:

1. 生成的Excel文件,完全(100%)符合Excel规范,即与用Excel编辑的文件完全一致

2. C#代码可以控制Excel内部的sheet,可以指定其立即刷新,如刷新Pivot Table

缺点:

1. 采用B/S架构时,服务器端必须与开发环境安装有同一个版本的Excel;采用C/S结构时,使用转出(生成)Excel文件的客户端必须与开发环境安装有同一个版本的Excel。

2. 使用Excel组件时,必须注意释放资源、关闭Excel进程、优化填充Excel的方法

下面,将结合本人的一些项目经验,谈谈如何在ASP.NET下,使用Office Excel (2007) 组件,将已经定义好的Excel模版填充数据,然后返回客户端。 (http://skywind.cnblogs.com

1.添加Excel组件的引用:

clip_image002[5]

2.打开需要填充的Excel模版,(我的项目中的做法是在这之前,先根据模版复制一份为需要填充的Excel模版)

clip_image004[4]

3.填充Excel

clip_image006[4]

这里面有两个提高填充效率和俗得的小的技巧

l 对于一个Range型的区域的数据,可以通过object[,]作为一个中介,整理好后一次性的插入Excel文件中;

l 操作时,对其Value2属性进行操作,Value2忽略单元格的格式,也可提高效率

4.刷新Pivot table等内容

clip_image008[4]

5.保存Excel文件

clip_image010[4]

6.关闭Excel进程,释放资源

clip_image012[4]

7。下载生成的Excel文件

clip_image014[4]

很遗憾,Office2007不完全遵从与OpenXML规范,据说要到Office2009才支持,到时候,对Excel操作就容易了!仅供参考,如果看官有更好的操作Excel的第三方组件或者源码推荐,欢迎交流。


本文转自Jack Niu博客园博客,原文链接:http://www.cnblogs.com/skywind/archive/2008/06/16/1222992.html,如需转载请自行联系原作者

相关文章
|
7天前
|
文字识别 BI
【图片型PDF】批量识别扫描件PDF指定区域局部位置内容,将识别内容导出Excel表格或批量改名文件,基于阿里云OCR对图片型PDF识别改名案例实现
在医疗和政务等领域,图片型PDF文件(如病历、报告、公文扫描件)的处理需求广泛。通过OCR技术识别这些文件中的文字信息,提取关键内容并保存为表格,极大提高了信息管理和利用效率。本文介绍一款工具——咕嘎批量OCR系统,帮助用户快速处理图片型PDF文件,支持区域识别、内容提取、导出表格及批量改名等功能。下载工具后,按步骤选择处理模式、进行区域采样、批量处理文件,几分钟内即可高效完成数百个文件的处理。
49 8
|
2月前
|
人工智能 自然语言处理 Java
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
FastExcel 是一款基于 Java 的高性能 Excel 处理工具,专注于优化大规模数据处理,提供简洁易用的 API 和流式操作能力,支持从 EasyExcel 无缝迁移。
234 9
FastExcel:开源的 JAVA 解析 Excel 工具,集成 AI 通过自然语言处理 Excel 文件,完全兼容 EasyExcel
|
2月前
|
C#
基于 C# 编写的 Visual Studio 文件编码显示与修改扩展插件
基于 C# 编写的 Visual Studio 文件编码显示与修改扩展插件
|
2月前
|
Python
批量将不同的工作簿合并到同一个Excel文件
本文介绍如何使用Python的`pandas`库批量合并不同工作簿至同一Excel文件。通过模拟生成三个班级的成绩数据,分别保存为Excel文件,再将这些文件合并成一个包含所有班级成绩的总成绩单。步骤包括安装必要库、生成数据、保存与合并工作簿。
71 6
|
2月前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分为多个工作表。本文通过一个具体示例,展示了如何根据学生班级将成绩数据拆分到不同的工作表中,并生成一个包含总成绩表和各班级成绩表的Excel文件。代码简洁明了,适合初学者学习和应用。
64 6
|
2月前
|
Python
按条件将Excel文件拆分到不同的工作表
使用Python的pandas库,可以轻松将Excel文件按条件拆分到不同的工作表中。本文通过一个示例代码展示了如何生成一个包含总成绩表和三个班级表的Excel文件。代码首先创建了一个包含学生姓名、班级和各科成绩的数据框,然后按班级分组,将每个班级的数据分别写入不同的工作表。最后,生成的Excel文件将包含四个工作表,分别为总成绩表和三个班级的成绩表。
52 6
按条件将Excel文件拆分到不同的工作表
|
3月前
|
前端开发
实现Excel文件和其他文件导出为压缩包,并导入
实现Excel文件和其他文件导出为压缩包,并导入
50 1
|
5月前
|
安全
猿大师办公助手在线编辑微软Office/金山wps网页组件COM加载项启用说明
猿大师办公助手是一款独特的在线编辑Office插件,不同于其他厂商的弹窗模式,它真正实现了网页内嵌本机Office。其COM加载项可在Office主菜单栏增加PageHi子菜单,提供文件保存、打印等功能,并能控制文档操作权限。安装后,默认自动启动COM加载项,但需注意可能被禁用或拦截,必要时需手动启用。对于WPS和微软Office,均有详细的启用步骤。
107 3
猿大师办公助手在线编辑微软Office/金山wps网页组件COM加载项启用说明
|
6月前
|
人工智能 自然语言处理 安全
微软会将ChatGPT整合纳入Office套件吗?
微软会将ChatGPT整合纳入Office套件吗?
55 0
|
9月前
微软Office 2019
微软办公软件套件Microsoft Office 2019 专业增强版2024年4月批量许可版更新推送!Office2019正式版2018年10月份推出,主要为多人跨平台办公与团队协作打造。Office2019整合对过去三年在Office365里所有功能,包括对Word、Excel、PowerPoint、Outlook、Project、Visio、Access、Publisher的更新。
196 2