VSTO学习笔记(二)Excel对象模型

原文:VSTO学习笔记(二)Excel对象模型

上一次主要学习了VSTO的发展历史及其历代版本的新特性,概述了VSTO对开发人员的帮助和效率提升。从这次开始,将从VSTO 4.0开始,逐一探讨VSTO开发中方方面面,本人接触VSTO时间不长,也是一次尝试。鉴于Excel在整个Office家族中的重要地位,故先从Excel开始介绍,后续内容会陆续介绍Word、PowerPoint、Outlook、InfoPath等。由于VSTO 4.0建立在Office 2010基础之上,先介绍一下Office 2010的新特性,注意现在只是Beta版,正式版可能还会有功能上的调整。

示例代码下载

本系列所有示例代码均在 Visual Studio 2010 Beta 2 + Office 2010 Beta 下测试通过

 

一、Office 2010新特性

微软将于2010年6月份正式推出Office 2010。Office 2010带来了诸多程序改进,保持了Office 2007的XML文件格式,改进了Ribbon界面,并带来了基于浏览器的Excel、Word、OneNote、PowerPoint作为Office网络应用服务,并首次提供64位的Office。

  Office 2010打破了微软的传统,成为全球最知名的在线Office工具,Office 2010中的基于Web的功能是全新的,因此可能会出现问题。由于对微软全新的Office在线体验持有怀疑的态度,虽然有些公司计划购买Office 2010,但是同时也会使用免费的Google Docs和Zoho。

Office Word 2010

Office Word 2010 增强了 Navigation Pane 特性,用户可在 Navigation Pane 中快速切换至任何一章节的开头(根据标题样式判断),同时也可在输入框中进行即时搜索,包含关键词的章节标题会高亮显示。例如下图中的搜索 LiveSino.net:

Office Word 2010 也增加了在线实时协作功能,用户可以从 Office Word Web App 中启动 Word 2010 进行在线文档的编辑,并可在左下角看到同时编辑的其他用户(包括其他联系方式、IM 等信息,需要 Office Communicator)。而当其他用户修改了某处后,Word 2010 会提醒当前用户进行同步。(注:此功能也存在于部分其他 Office 2010 程序中)

另外,用户可在 Office Word 2010, Office PowerPoint 2010 以及 Office OneNote 2010 等 Office 2010 程序中直接插入其他正在运行的软件的截图。

Office Excel 2010

Office Excel 2010 新增了 Sparklines 特性,可根据用户选择的数据直接在单元格内画出折线图、柱状图等,并配有 Sparklines 设计面板供自定义样式。

Office PowerPoint 2010

Office PowerPoint 2010 除了新增更多幻灯片切换特效、图片处理特效之外,还增加了更多视频功能,用户可直接在 PowerPoint 2010 中设定(调节)开始和终止时间剪辑视频(见下图),也可将视频嵌入之 PowerPoint 文件中。

PowerPoint 2010 左侧的幻灯片面板也新增了分区特性,用户可将幻灯片分区归类,也可对整个区内的所有幻灯片进行操作。见下图中的 Default Section 和 LiveSino Section。

PowerPoint 2010 也增加了类似格式刷的工具 – Animation Painter,可将动画效果应用至其他对象,用法同格式刷。另外就是上次我提到的 Broadcast Slide Show 在线幻灯片播放功能。

Office 2010 其他组件包括 OneNote 2010, Access 2010, InfoPath 2010, Publisher 2010 都包含了不少新特性,并且都已采用 Ribbon UI 但我不打算详细介绍。

Office Web Applications 2010

Office Web Applications 2010 包含 Word Web App, Excel Web App, PowerPoint Web App 以及 OneNote Web App,支持简单的编辑及实时协作功能,支持 IE, Firefox, 和 Safari。具体内容后文中介绍,另附清晰截图如下:

 

Office Mobile 2010

Office Mobile 2010 包含新版 Word Mobile, Excel Mobile, PowerPoint Mobile, OneNote Mobile 以及支持对话模式的 Outlook Mobile(见下图,来源:SuperSite)。

企业服务器端也可渲染 Office 文档供企业移动用户通过手机端查看 Office 文档,也支持黑莓和 iPhone。

WZor.net 泄漏了 Microsoft Office 2010 Professional Plus 技术预览版(x86, x64),而 Ars Technica 在第一时间发布了全套 Office 2010 截图。尽管对比 1 个月前泄漏的 Outlook 2010 截图,界面并没有太大改动,但最近的 TechED 09 以及该泄漏版 Office 2010 中暗示了些 Office 2010 的新特性。

Windows 7 Jump Lists

在 TechEd 2009 上,微软演示了支持 Windows 7 Jump Lists 新特性的 Outlook 2010。当有未读邮件时。Outlook 任务栏图标右下角还包括新邮件的图标提示(如下图)。(via Techradar

Microsoft PowerPoint Live(Broadcast Slide Show)

PowerPoint 2010 支持将演示文档发布至 PowerPoint Live 或其他在线服务,以便其他用户可通过浏览器观看该演示文档,类似 Apple iWork.com。而 PowerPoint Live 很可能就是 Office Web Applications 中的一员。

JCXP 还给出了一些 PowerPoint 2010 以及 Word 2010 新特性的截图和简介,比如:PowerPoint 截图功能、新的 PowerPoint 过渡效果、PowerPoint 内录制幻灯演示。

另外,Office 2010 官方团队也已确认:Groove 已改名为 SharePoint Workspace,并且 OneNote 和 SharePoint Workspace 都将包括于 Pro Plus 版本中。

我已经安装了Office 2010 Professional Plus Beta X64:

如上文介绍的,InfoPath和Groove的命名发生了变化,其他不变。个人感觉Office 2010中最大的变化是对在线办公的支持,这是未来发展的趋势,个人表示看好。其他新功能我会陆续尝试,会发布在后续篇章,以VSTO 4.0来体验新特性。

 

二、Excel对象模型

对象模型是一组由Office应用程序提供的对象,用来控制Office应用程序,是VSTO开发的核心内容。其中Application是最顶层的对象,负责对Office进行整体的控制,类似于.Net WinForm和WPF中的Application对象,是根对象。Workbook(s)指工作簿,Worksheet(s)指工作表,Chart(s)指各种图表。Sheets对象比较特别,它包含Worksheet或Chart类型的对象,而Range表示希望操作的单元格范围。

 

三、主互调程序集(PIA)

用于与Office交互的托管程序集叫做Office主互调程序集(PIA)。

PIA = Primary Interop Assemblies

通常应用一种被称为COM Interop的.Net技术与Office对象模型进行交互,所有的Office对象都是用非托管代码(C、C++)编写的,并提供COM接口。为了在托管代码中与这些接口进行通信,必须使用封装器,通过封装器来实现托管代码与Office非托管COM接口之间的协同工作。该封装器是一系列的.Net类,他们被编译为PIA程序集。之所以PIA称之为"主",是因为开发人员可以开发自己的封装器IA(Interop Assemblies),除非有非常特殊的需求,否则不建议使用自己的IA,因为这不能够与其他的Office解决方案进行交互,而且有可能包含Office已经修复的bug。

安装相应的Office版本后就会安装PIA了,如果要开发VSTO 4.0,建议安装Office 2010 Professional Plus Beta。Office PIA被安装到GAC(GAC = Global Assembly Cache)中。

大部分VSTO项目会自动添加PIA,如果创建的是其他类型的项目(控制台、类库、WinForm、WPF等),则需要手动添加PIA。

说明

程序集名称

命名空间

Microsoft Office 14.0 Object Library

Office.dll

Microsoft.Office.Core

Microsoft Excel 14.0 Object Library

Microsoft.Office.Interop.Excel.dll

Microsoft.Office.Interop.Excel

Microsoft Word 14.0 Object Library

Microsoft.Office.Interop. Word.dll

Microsoft.Office.Interop. Word

Microsoft Outlook 14.0 Object Library

Microsoft.Office.Interop. Outlook.dll

Microsoft.Office.Interop. Outlook

Microsoft Graph 14.0 Object Library

Microsoft.Office.Interop. Graph.dll

Microsoft.Office.Interop. Graph

Microsoft.SmartTags 2.0 Type Library

Microsoft.Office.Interop.SmartTag.dll

Microsoft.Office.Interop.SmartTag

当PIA之间有依赖关系时,VS2010会自动添加必须的PIA。

 

四、Office解决方案

1、Office自动化程序(Office Automation Executable)

Office自动化程序是独立于Office的程序,用于控制和自动化处理某个Office应用程序。如控制台、类库、WinForm、WPF等。

2、Office加载项(Add-In)

Office加载项是某个程序集(dll)中的类,Office在需要时可加载和创建它,加载项可以直接在Office应用程序的进程中运行,而不需要在独立于Office应用程序的进程中运行,加载项在Office应用程序的整个生命周期中均保持加载状态。

3、Office文档代码(Code Behind on Office Document)

Office文档代码早在VBA时代就已经得到了广泛的应用,在VSTO中得到了进一步的增强。Office文档代码可以用某种方式对Office应用程序进行定制,如增加只在当前文档中才出现的菜单项,或者在文档打开时触发事件。

4、Office 模板(Office Template)

使用托管代码创建相应的Office模板。

5、服务器文档模式(Server Document)

VSTO可以在不打开Office应用程序的情况下,在服务器端运行程序并对存放在Office文档中的数据进行操作,如VSTO的缓存数据功能,SharePoint 2007/ 2010的Excel Services等。

6、OpenXML模式

以OpenXML的API操作Office文档中的数据,结合XSLT等转换为需要的文档格式。关于OpenXML的介绍请参阅我博客的另外一个系列:OpenXML学习笔记。

 

五、Office文档代码示例

由于本次主要学习Excel对象模型,顾采用Office文档代码模式做几个简单的练习,其余模式后续篇章会陆续介绍。

1、新建一个Excel 2010 Workbook项目:

 

默认添加的引用和项目文件:

 

2、在Sheet1中添加两个Button和一个Label控件:

 

3、添加事件处理代码:

 

ExpandedBlockStart.gif代码
        private void btnPIA_Click(object sender, EventArgs e)
        {
            Excel.Workbook book 
= this.Application.Workbooks[1];
            Excel.Worksheet sheet 
= book.Worksheets[1];//C# 4.0新特性,PIA动态导入。
            this.labMsg.Text = "这是PIA调用结果,当前工作表名为: " + sheet.Name;
        }

        
private void btn获取工作表_Click(object sender, EventArgs e)
        {
            
this.labMsg.Text = string.Empty;
            Excel.Workbook book 
= this.Application.Workbooks[1];

            
for (int i = 1; i <= book.Worksheets.Count; i++)
            {
                
//C# 4.0新特性,PIA动态编译。
                this.labMsg.Text += book.Worksheets[i].Name + " ";
            }
        }

受益于C# 4.0的新特性,可以不用进行显示类型转换了,同时PIA将在运行时进行导入、编译,注意:VSTO中的索引大多数是从1开始,而不是从0.

 

4、F5运行,将会打开生成的Excel:

 

5、运行结果:

 

六、小结

本次首先叙述了Office 2010的新特性,学习了VSTO开发的基础知识,对PIA有了深刻的认识,介绍了不同的Office解决方案的区别。最后用 Excel文档代码做了一个简单的示例,利用C# 4.0的新特性,使得VSTO 4.0的开发更加便捷、高效。如果你还不熟悉C# 4.0,不妨先看看园子里的相关文章,若要调试本示例代码,需要安装VS2010 Beta2 + Office 2010 Beta。下一次将继续学习Excel的相关知识,我们将使用VSTO来编写一个Excel自定义公式,比较其与VBA的不同。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/460098.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

zen-coding for notepad++,前端最佳手写代码编辑器

zen-Coding是一款快速编写HTML,CSS&#xff08;或其他格式化语言&#xff09;代码的编辑器插件&#xff0c;这个插件可以用缩写方式完成大量重复的编码工作&#xff0c;是web前端从业者的利器。 zen-Coding插件支持多种编辑器&#xff0c;如UltraEdit&#xff0c;Notepad等。 温…

red hat linux 远程,Red Hat Linux 远程桌面 – 如何设置

远程访问 RHEL 计算机。运行 RHEL 7.3-8.1 的 Linux 计算机的远程桌面。从任何计算机、平板电脑或移动设备进行访问。立即免费试用&#xff01;如果您是在家中或在旅途中工作&#xff0c;则可能需要一段时间才能在办公室或在家中访问台式计算机。如果该桌面恰巧在 Linux 操作系…

通过boundingRectWithSize:options:attributes:context:计算文本尺寸

转&#xff1a;http://blog.csdn.net/jymn_chen/article/details/10949279 之前用Text Kit写Reader的时候&#xff0c;在分页时要计算一段文本的尺寸大小&#xff0c;之前使用了NSString类的sizeWithFont:constrainedToSize:lineBreakMode:方法&#xff0c;但是该方法已经被iOS…

移动后端支持平台Parse将API由Ruby迁移到Go

Charity Majors是移动后端支持平台Parse的工程师。近日&#xff0c;他撰文介绍了他们将API从Ruby迁移到Go的过程。\\2011年&#xff0c;Parse借助Ruby on Rails快速推出了第一个版本。他们用Unicorn作为HTTP服务器&#xff0c;用Capistrano部署代码&#xff0c;用RVM管理环境&a…

linux 虚拟钢琴程序,基于 Linux 与 VS1003 的 MIDI 电子节拍器的设计与实现,为乐器演奏(如钢琴、吉他)...

基于 Linux 与 VS1003 的 MIDI 电子节拍器的设计与实现&#xff0c;为乐器演奏(如钢琴、吉他)2016-08-22 0 0 0 4.0分其他1积分下载如何获取积分&#xff1f;基于 Linux 与 VS1003 的 MIDI 电子节拍器的设计与实现&#xff0c;为乐器演奏(如钢琴、吉他)提供稳定&#xff0c;丰富…

一个从源代码里提取中文字符串的java类

2019独角兽企业重金招聘Python工程师标准>>> 工作中需要优化代码里的中文警示语和异常信息&#xff0c;实在比较多&#xff0c;所以就写了个程序专门从代码里提取中文字符串。 java做的&#xff0c;比较简单&#xff0c;放上来备忘 package com.extractstr.app;impo…

oracle RAC切换归档

&#xff08;转自leshami&#xff09; RAC环境下的归档模式切换与单实例稍有不同&#xff0c;主要是共享存储所产生的差异。在这种情况下&#xff0c;我们可以将RAC数据库切换到非集群状态下&#xff0c;仅仅在一个实例上来实施归档模式切换即可完成RAC数据库的归档模式转换问…

linux启用ipmi服务,使用 ipmitool 实现 Linux 系统下对服务器的 ipmi 管理

简介&#xff1a; IPMI 是一种可扩展的标准&#xff0c;它定义了如何监控硬件和传感器、控制系统部件以及记录重大事件&#xff0c;随着 ipmi 技术在服务器中的应用&#xff0c;利用 ipmi 的众多优势就成为服务器管理特别是集群管理中不可缺少的部分。本文首先介绍了 ipmi 的一…

linux中bc用法英文,使用GNU bc在Linux Shell中进行数学运算

在 shell 中使用 bc 更好地做算数&#xff0c;它是一种用于高级计算的数学语言。大多数 POSIX 系统带有 GNU bc&#xff0c;这是一种任意精度的数字处理语言。它的语法类似于 C&#xff0c;但是它也支持交互式执行语句和处理来自标准输入(stdin)的数据。因此&#xff0c;它通常…

Linux C Socket编程原理及简单实例

部分转自&#xff1a;http://goodcandle.cnblogs.com/archive/2005/12/10/294652.aspx 1. 什么是TCP/IP、UDP&#xff1f; 2. Socket在哪里呢&#xff1f; 3. Socket是什么呢&#xff1f; 4. 有很多的框架&#xff0c;为什么还在从Socket开始&#xff1f; 5. Linux C…

蜉蝣极客

蜉蝣极客 百科名片 蜉蝣目&#xff08;英文&#xff1a;mayfly&#xff0c;学名&#xff1a;Ephemeroptera&#xff09;通称蜉蝣&#xff0c;具有古老而特殊的性状&#xff0c;是最原始的有翅昆虫。和蜻蜓目可同分为古翅次纲&#xff0c;他们的翅不能折叠。蜉蝣目昆虫体形细长…

解决Web部署 svg/woff/woff2字体 404错误

原文:解决Web部署 svg/woff/woff2字体 404错误问题&#xff1a;最近在IIS上部署web项目的时候&#xff0c;发现浏览器总是报找不到woff、woff2字体的错误。导致浏览器加载字体报404错误&#xff0c;白白消耗了100-200毫秒的加载时间。 原因&#xff1a;因为服务器IIS不认SVG&am…

压缩感知先进——关于稀疏矩阵

前《初识压缩感知Compressive Sensing》中我们已经讲过了压缩感知的作用和基本想法&#xff0c;涉及的领域&#xff0c;本文通过学习陶哲轩对compressive sensing&#xff08;CS&#xff09;的课程&#xff0c;对压缩感知做进一步理解。针对其原理做出解说。本文较为理论性&…

基于环信sdk的陌生人交友php服务器代码开源

2019独角兽企业重金招聘Python工程师标准>>> 这个是代码结构 服务器端需要两个服务器端软件的支持&#xff1a; 1&#xff1a;weed-fs golang写的海量小文件存储工具 2&#xff1a;memcache 流行的缓存服务器 服务器端主要配置是 conf.php 文件&#xff0c;配置数据…

Linux视频 pad,Wine 1.9.10 发布下载, 改善视频输出

Wine 1.9.10最近发布下载&#xff0c;改进了大量的新功能和错误修正。一个显著的更新是此版本改善视频输出&#xff0c;更兼容目录列表&#xff0c;修复一些C 运行时。Wine 1.9.10 Bug 修复Month calendar control uses 0sunday for firstDayOfWeektooltips not working proper…

EXCEL数据导入dataset

一、开工必备 1、micorosoft office2007 2、VS2010、Oracle 11 二、界面 三、内部代码 (1)获取数据库连接&#xff0c;定义全局变量 private static string connString System.Configuration.ConfigurationSettings.AppSettings[ "connStr" ]; D…

JDBC连接MySQL数据库及演示样例

JDBC是Sun公司制定的一个能够用Java语言连接数据库的技术。 一、JDBC基础知识 JDBC&#xff08;Java Data Base Connectivity,java数据库连接&#xff09;是一种用于执行SQL语句的Java API&#xff0c;能够为多种关系数据库提供统一訪问&#xff0c;它由一组用Java语言…

Single Image Haze Removal(图像去雾)-CVPR’09 Best Paper

公式推导 paper闪光点 找到了一个很简洁的假设。 paper不足 代码跑起来很慢。据说2010年的ECCV那篇是改进的。

EasyUI学习总结(二)——easyloader分析与使用

使用脚本库总要加载一大堆的样式表和脚本文件&#xff0c;在easyui 中&#xff0c;除了可以使用通常的方式加载之外&#xff0c;还提供了使用 easyloader 加载的方式。这个组件主要是为了按需加载组件而诞生。什么情况下使用它呢&#xff1f; 你觉得一次性导入 easyui 的核心 m…

c语言switch scanf语句,C语言中scanf函数与switch语句

----------------switch----------------1)使用格式switch(表达式){case 常量表达式1: 语句1;case 常量表达式2: 语句2; ...case 常量表达式n: 语句n;default: 语句n1;}判断月份代码实现int main(int argc, const char * argv[]) {//定义变量int month;//提示用户输入一个月份p…