转载:http://www.cnblogs.com/oneivan/p/4243574.html

背景:一年前,某项目需要使用到Excel进行数据录入,考虑到很多用户还是使用XP+Office 2003,所以开发的时候直接使用Excel 2003版本进行VBA开发。也许很多人都会说,Win10都出了,微软的Office都要免费了,还用Office2003???但客户是上帝!

大概开发过程:用户直接打开一个Excel文件,Excel文件提示用户登陆;登陆之后,看到待办任务;选择待办任务,打开对应的Excel表单模板进行数据录入;保存提交。以上操作,Excel里的VBA都会以服务器里的服务服务交互(废话)。

问题来了,因为VBA是直接嵌入到Excel文件里的,只有一个项目的时候,维护更新起来还不是很麻烦,但是当其它项目也想使用此Excel程序,就头痛了,总不能每个项目一套VBA代码吧。。。

Why not VSTO (Visual Studio Tools for Office) ?

VSTO的受众是“专业开发者”,可以理解为靠它赚钱,如果是处理日常工作中的问题vba更合适。OK,我们好歹也是“专业开发者”,那试试用VSTO吧。

相信很多人都跟我一样,开发机装的都是Win7+、VS2012+、Office2010+。

1、VS2012和Office2010环境

没有犹豫的,我首先是尝试直接在VS2012和Office2010下进行Excel2003 VSTO 的开发。新建 - Office - Excel2010工作薄 - 确定,在向导页面,下拉选项里确实也可以看到97-2003选项。选择03格式后,生成、F5都没有问题。

接下来,简单制作了个安装包。在开发机安装,成功运行!关键的是,把安装包拿到虚拟机(xp、office2003),运行时提示未能加载公共语言运行库,相关的Net Framework是已经安装了的!P.S:如果不是用安装包部署,直接拷VS Bin目录下的文件到虚拟机,会提示未能找到addin元素。

上面这个问题纠结了一阵之后,才终于意识到VS2010以上的版本是已经不支持Office 2003 的VSTO了。

2、VS2005和Office2003环境

重新开了个虚拟机,然后从网上下载了个VS2005的中文版(虽然说“过时”了,但网上还是有一大堆下载的)。然后再下载Office2003完整版。看到园子这篇文章说VS和Office的安装先后顺序,我还是特意先安装Office的。

把VS2005的SP1也打上了。

来看看VS2005令人念旧的界面。

在VS2005,新建Office项目时,默认只有那么几个选项,如下图所示。

生成、调试什么的,一切都还正常。然后准备部署。嗯,对了,贴上经典的两篇MSDN文章的链接。

Deploying Visual Studio 2005 Tools for Office Solutions Using Windows Installer (Part 1 of 2)

Deploying Visual Studio 2005 Tools for Office Solutions Using Windows Installer: Walkthroughs (Part 2 of 2)

第一眼看上去,还真的是“长篇大论”,满眼的E文,看到头都有点痛,一目十行地看了一下,然后动手新建VS Setup Project。

在添加Prerequisites(系统必备)时,发现列表里打不到Office runtime和Office tools。好吧,又是百度(基本上没有找到有用的),又是谷歌,还把Office重装了,Vs修复了,那几个东西依旧躲猫猫。

山穷水尽疑无路的时候,重新看回Deploying Visual Studio 2005 Tools for Office Solutions Using Windows Installer (Part 1 of 2)。耐心地看下去,蓦然发现:“

Adding the Visual Studio 2005 Tools for Office Packages to the Bootstrapper

The following instructions describe how to add the packages listed above to the bootstrapper package directory. These changes need only be made once and only on the development computer.

For this task, you must have the files that are available in the Windows Installer that accompanies this article. You must prepare the files before you copy them into the bootstrapper package directory.

Preparing the Office Application and Office Primary Interop Assemblies Checks

You must compile the Office application and primary interop assembly checker program samples.

......”

晕啊,不是所有的教程贴都是有图有真相的。如何添加Office包到安装启动器的步骤被我忽略了!下面对原文的操作步骤简单的用自己话翻译下来。

 ①安装.NET Framework 2.0 software development kit (SDK)and the Windows Platform SDK (在线安装链接)

这些默认是没有和vstor一起安装的,需要自己去微软下载中心下载安装。后者在线安装时间比较长,需要耐心等待。建议直接下载硬盘版本,本地完全安装

如果用的是 Microsoft Visual Studio Team System,则这些不是必需的。

②编译检查程序

原文有提供一个代码示例和部署工具的集合安装包,需要下载并安装,然后在

C:\Program Files\Microsoft Visual Studio 2005 Tools for Office Resources\VSTO2005 Windows Installer Sample

可以看到相关的文件,简称此目录为{SamplesDir}。

打开VS2005命令提示,cd到{SamplesDir}\projects\Checks目录。

先后输入以下命令:

cl.exe -I "C:\Program Files\Microsoft Platform SDK\Include" /Oxs /MT /GS AppCheck.cpp  
此时可以看到目录下面多出了几个文件


cl.exe -I "C:\Program Files\Microsoft Platform SDK\Include" /Oxs /MT /GS PIACheck.cpp "C:\Program Files\Microsoft Platform SDK\Lib\advapi32.lib"
如果没有成功安装 the Windows Platform SDK,会提示无法打开输入文件哦。 然后把生成的PIACheck.exe 复制到{SamplesDir}\packages\Office2003PIA.

 
③准备Office 2003 primary interop assemblies(交互程序集)
下载并解压 Office 2003 Update: Redistributable Primary Interop Assemblies ,然后把解压得到的O2003PIA.msi 复制到{SamplesDir}\packages\Office2003PIA文件夹。
④准备Visual Studio 2005 Tools for Office Runtime(运行时)
下载,把vstor.exe 复制到{SamplesDir}\packages\VSTORuntime文件夹
⑤准备Visual Studio Tools for Office Language Pack (语言包)
下载,把 vstolp20.exe 复制到 {SamplesDir}\packages\VSTOLP文件夹
⑥把打包信息目录拷贝到启动加载器目录
原文是这样说的
In Visual Studio 2005 Tools for Office, the default directory is here:
C:\Program Files\Microsoft.NET\SDK\v2.0\BootStrapper\Packages\
In Visual Studio Team System, the default directory is here:
C:\Program Files\Microsoft Visual Studio 8\SDK\v2.0\BootStrapper\Packages
我的是VS2005 SE、Windows Server 2003,找不到第一个路径,就只好把它拷到第二个目录了。
C:\Program Files\Microsoft Visual Studio 8\SDK\v2.0\BootStrapper\Packages

到此,算是告了一个基本段落,重新打开VS2005,可以看到在系统必备里,那几个东东是终于跑出来了!

尝试Office 2003 VSTO的开发、部署的更多相关文章

  1. 三种扩展 Office 软件功能的开发模型对比 – Office Add-In Model, VBA 和 VSTO

    当 Office 用户需要针对文档自定义新功能时,可以求助于 VBA 或者 VSTO 两种方式.Office 2013 富客户端以后,微软为 Office 平台上的开发者提供了一种新模型 --- Of ...

  2. VSTO 学习笔记(十三)谈谈VSTO项目的部署

    原文:VSTO 学习笔记(十三)谈谈VSTO项目的部署 一般客户计算机专业水平不高,但是有一些Office水平相当了得,尤其对Excel的操作非常熟练.因此如果能将产品的一些功能集成在Office中, ...

  3. 深入理解vsto,开发word插件的利器

    开发了vsto,客户那边也有一些反映插件安装失败或者加载不上的情况.于是我下定决定再理解下vsto的工作机制,如下图: 如上图所示,我把vsto的解决方案分为两部分,一部分是vsto Add-ins, ...

  4. 初识VSTO Addin开发

    这篇博客将简单介绍一些VSTO Addin开发的知识. 1. VSTO是什么?我们可以用VSTO做什么? VSTO全称Visual Studio Tool for Office,是可以让我们针对现有的 ...

  5. 接触vsto,开发word插件的利器

    研究word插件有一段时间了,现在该是总结的时候了. 首先咱们来了解下什么是vsto?所谓vsto,就是vs面向office提供的一个开发平台.一个开发平台至少包含两个要素:开发工具(sdk)和运行环 ...

  6. 让开发部署提速 8 倍,我参与贡献这款 IDE 插件的全过程

    如何像参与开源那样,去参与一款 IDE 插件的设计? 作为一款 IDE 插件的使用者,我是否能决定下一个版本的功能? 自从产品经理银时小伙和他的开发小哥们在去年12月发布 Cloud Toolkit( ...

  7. 使用ASP.NET MVC、Rabbit WeixinSDK和Azure快速开发部署微信后台

    (此文章同时发表在本人微信公众号"dotNET每日精华文章",欢迎右边二维码来关注.) 题记:公众号后台系统和数据都基本准备妥当了,可以来分享下我是如何开发本微信公众号的后台系统了 ...

  8. office 2003和office 2013同时安装使用的问题

    电脑上同时安装了Office 2003和Office 2007/2010,先打开Word 2003,然后再打开Word 2010,总会弹出安装配置界面,反之亦然.  解决方法:使用快捷键Win+R打开 ...

  9. 开发部署一个简单的Servlet

    Servlet是一个执行在服务器端的Java Class文件,载入前必须先将Servlet程序代码编译成.class文件,然后将此class文件放在servlet Engline路径下.Servlet ...

随机推荐

  1. 《LeetBook》leetcode题解(6): ZigZag Conversion[E]

    我现在在做一个叫<leetbook>的免费开源书项目,力求提供最易懂的中文思路,目前把解题思路都同步更新到gitbook上了,需要的同学可以去看看 书的地址:https://hk029.g ...

  2. 微服务Kong(七)——CLI参考

    KONG提供了一套CLI(命令行界面)命令,您可以通过它来启动.停止和管理您的Kong实例.CLI管理您的本地节点(如在当前机器上). 全局配置 所有命令都采用一组指定的可选标志作为参数: --hel ...

  3. maven在pom文件中添加你想要的jar包

    概述:POM 文件里面的依赖jar包经常需要添加, 仅需要在google中代码查找 :maven 你需的jar包名称 repository 用了Maven,所需的JAR包就不能再像往常一样,自己找到并 ...

  4. C#、OC递归锁

    做ios也有1年了,C#的东西有些都忘记了,最近几天也打算重温一下,不能学了ios把C#给抛弃了,两者都要抓,一精多专.目前C#只是重温,重点是web这块.今天主要是想起了之前做过的面试题,虽然题比较 ...

  5. [转]OPEN(SAP) UI5 学习入门系列之一:扫盲与热身(上)

    本文转自:http://www.cnblogs.com/qianmarv/p/4671394.html 1 扫盲 什么是SAP Fiori? 了解SAP UI5必须要从SAP Fiori开始,两者概念 ...

  6. Python——基本的书写规则

    1.输入方法input() 等待用户输入数据,并回车后得到数据(name为输入的字符串) name=input('Please input your name:') print('Hi,',name) ...

  7. RabbitMQ---7、常见参数含义

    简介 本节主要讨论队列声明的各个参数 queueDeclare(String queue, boolean durable, boolean exclusive, Map<String, Obj ...

  8. MySQL---3、常用命令大全

    一.连接MySQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1.例1:连接到本机上的MYSQL. 首先在打开DOS窗口,然后进入目录 mysqlbin,再键入命令mysql -ur ...

  9. Sublime Text - 在浏览器打开当前文件

    有没有办法通过快捷键在指定的浏览器中打开当前文件? 有点怀念Dreamweaver的F12? 其实Sublime也可以实现这一效果,而且不需要安装任何插件. 进入Tools -> Build S ...

  10. 数据结构(三)--- B树(B-Tree)

       文章图片代码来自邓俊辉老师的课件 概述 上图就是 B-Tree 的结构,可以看到这棵树和二叉树有点不同---"又矮又肥".同时子节点可以有若干个小的子节点构成.那么这样一棵树 ...