最近很多朋友向我提出Office的开发方式方面的疑惑,主要是针对特定的系统和Office版本不知道选择哪一种编程语言、创建哪一种类型的项目。

事实确实如此,如果搞不清楚语言的特性和项目类型的特点,很可能走很多弯路。也可能导致开发完的产品不能部署在客户电脑上。

无论从哪一个角度讲,Office开发都是一个相当庞大、复杂的话题。

下面是我整理出的一个按照开发项目分类的表格(*凡是写有VB.NET的地方,表示C#语言也可以做到)。

话题1:32位和64位的问题

Windows系统分为32位和64位。

32位系统中只能安装32位Office。

64位系统中可以安装32位Office,也可以安装64位Office。

有的同学不知道现在用的Office是多少位,查看方法是,Excel中点击【文件】,进入Backstage视图,选择【账户】,点击“关于Excel”

弹出一个对话框,写着32位。

我经过开发和测试,发现VB6开发的dll文件不能用于64位Office及其VBA环境。

但是,VB6开发的VB6外接程序,可以用在64位系统中的VB6,这可能是VB6本身不区分32和64位。

这样得出如下结论:

64位系统下的64位Office,这种环境下就别思考用VB6去开发Office的COM加载项,以及VBA的加载项了。

那么剩下的其他情况,仍然可以使用VB6。

话题2:动态链接库、自定义函数、外接程序的区别

以上三个名词,确实有联系也有区别。

  • 动态链接库一般指的是用VB6创建的ActiveX DLL项目,编译生成后的是一个dll文件。可以在VBA工程或VB6工程中的引用中使用该dll文件,从而在代码中调用dll中的函数和方法。也就是说:动态链接库通常没有界面,只让你从其他程序代码中调用封装在dll中的函数。
  • 自定义函数,通常指的是Excel工作表中的扩展函数,这种自定义函数可以像SUM、Average一样被使用。自定义函数可以来源于VB制作的动态链接库,也可以来源于VB.NET制作的类库项目,还可以来源于Excel-DNA项目。
  • 外接程序指的是寄生在Office或VBA或VB6中的COM加载项,使用VB6创建ActiveX DLL项目就可以实现多个Office组件共享的COM加载项,也可以开发VBA、VB6编程环境中的COM加载项。同样使用VB.NET也可以做到。

话题3:如何判断一个COM加载项是哪一种项目类型做出的?

很多情况下,别人发给我一个安装包,我安装了以后可以正常使用,但是怎么知道这个产品是哪种开发方式呢?

下面介绍一个粗略的方法。

在COM加载项对话框中,选中那个你比较关心的COM加载项,看他的位置。如果显示的是mscoree.dll,那应该是VB.NET或C#开发的外接程序项目。

位置中格式如file:///...|vstolocal,这种的是VSTO外接程序项目。

如果位置中,是本地磁盘中明确的一个dll文件的路径,可能是VB开发的COM加载项。

话题4:COM加载项开发过程中的自定义界面如何选择

如果开发对象是Office 2003,只能自定义菜单和工具栏,插件加载时创建自定义工具栏,卸载时删除工具栏。如果不删除工具栏,会产生垃圾。

如果开发对象是VBA或VB6编程环境,也只能自定义菜单和工具栏。

如果开发对象是Office 2007以上版本,可以使用自定义菜单和工具栏、使用Ribbon XML自定义功能区等,也可以创建任务窗格。

总结:

  • VB6和VB.NET都可以作为Office和VBA的开发语言,都可以创建共享外接程序,可以在一个工程或项目内部实现多个COM加载项。而且,这种开发方式不限组件,只要有COM对话框的Office组件都可以用以上语言开发,例如开发Access的COM加载项。
  • 从语言本身来讲,VB.NET比VB6强大。
  • 上面表格中列出的15种开发方式,我都亲手实践过,结论可靠。
  • 其中VBE2014、VBE2019、Favorite、API函数库是颇具代表性的作品。

本贴中写的不严谨的地方,大家可以发邮件至32669315@qq.com联系我。

如果大家对上面那一部分感兴趣,可以翻看我的博客园中其他博文。

Office、VBA开发方案选择指南的更多相关文章

  1. Office VBA开发经典-中级进阶卷 配套资源下载

    本书源代码请到如下页面寻找: https://www.cnblogs.com/ryueifu-VBA/p/8982192.html

  2. 刘永富的Office/VBA/VSTO开发资源分享

    各种常用安装包下载:https://share.weiyun.com/5PCvqY4 简称 文件名称 描述信息 视频课程 虚拟光驱软件Daemon DAEMON_Tools_Lite_V10.1.0. ...

  3. 所有人都可以是开发人员——《Office 365开发入门指南》视频教程即将上市

      今天是春节假期的最后一天,在这里给全国的朋友们拜个晚年,祝大家身体健康,晚年幸福啊.这个春节大家过的怎么样啊,我自己是在老家过的年,家乡的年味还是比较浓的,也再次感谢朋友圈的大家给我看了各地的风光 ...

  4. 《Office 365开发入门指南》上市说明和读者服务

    写在最开始的话 拙作<Office 365开发入门指南>上周开始已经正式在各大书店.在线商城上市,欢迎对Office 365的开发.生态感兴趣的开发者.项目经理.产品经理参考本书,全面了解 ...

  5. 《Office 365开发入门指南教程》正式上线,限时优惠和邀请分享推广

    我很高兴地通知大家,<Office 365 开发入门指南教程>已经正式在网易云课堂上线,你可以通过直接访问  https://aka.ms/office365devlesson 这个短地址 ...

  6. 如何选择PHP项目的开发方案?

    我说的项目开发方案并不是谈论到底用不用PHP去开发的问题,而是当你遇到一个项目,已经决定了用PHP,然后才来看的问题:用PHP的什么开发方案. 基本上有这么几种方案.各有各的说法,良莠不齐,我就谈谈我 ...

  7. 《Office 365 开发入门指南》公开邀请试读,欢迎反馈

    终于等来了这一天,可以为我的这本新书画上一个句号.我记得是在今年的2月份从西雅图回来之后,就萌发了要为中国的Office 365开发人员写一些东西并最终能帮到更多中国用户的想法,而从2月26日正式写下 ...

  8. Office 365开发概述及生态环境介绍(二)

    本文于2017年3月19日首发于LinkedIn,原文链接在这里 在上一篇 文章,我给大家回顾了Office发展过来的一些主要的版本(XP,2003,2007,2013等),以及在Office客户端中 ...

  9. C# -- HttpWebRequest 和 HttpWebResponse 的使用 C#编写扫雷游戏 使用IIS调试ASP.NET网站程序 WCF入门教程 ASP.Net Core开发(踩坑)指南 ASP.Net Core Razor+AdminLTE 小试牛刀 webservice创建、部署和调用 .net接收post请求并把数据转为字典格式

    C# -- HttpWebRequest 和 HttpWebResponse 的使用 C# -- HttpWebRequest 和 HttpWebResponse 的使用 结合使用HttpWebReq ...

随机推荐

  1. 《新标准C++程序设计》1.7-1.10(C++学习笔记2)

    1.内联函数(inline关键字) eg.inline int Max(int a,int b) { if(a>b) return a; return b; } 当编译器处理调用内联函数的语句时 ...

  2. 输入框中提示信息(html5)

    placeholder 属性规定可描述输入字段预期值的简短的提示信息(比如:一个样本值或者预期格式的短描述). 该提示会在用户输入值之前显示在输入字段中. 注意:placeholder 属性适用于下面 ...

  3. Codeforces 442A Borya and Hanabi

    有五种花色 外加 五种点数 共25张牌,每次有n张牌,主人知道这n张牌中有哪些牌,并且哪种牌有几张,但是不知道具体是哪张牌,他可以问某种花色,然后知道了哪几张是该花色,也可以问点数,然后就知道了哪几张 ...

  4. 技术沙龙|京东云DevOps自动化运维技术实践

    自动化测试体系不完善.缺少自助式的持续交付平台.系统间耦合度高服务拆分难度大.成熟的DevOps工程师稀缺,缺少敏捷文化--这些都是DevOps 在落地过程中,或多或少会碰到的问题,DevOps发展任 ...

  5. 201771010123汪慧和《面向对象程序设计Java》第十八周实验总结

    一.总复习纲要 1. Java语言特点与开发环境配置(第1章.第2章) 2. Java基本程序结构(第3章) 3. Java面向对象程序结构(第4章.第5章.第6章) 4. 类.类间关系.类图 5. ...

  6. MyBatis:一对多、多对一处理

    多对一的处理 多对一的理解: 多个学生对应一个老师 如果对于学生这边,就是一个多对一的现象,即从学生这边关联一个老师! 数据库设计 CREATE TABLE `teacher` ( `id` INT( ...

  7. [极客大挑战 2019]Upload

    0x00 知识点 一个常规上传题目,知识点全都来自前几天写的文章: https://www.cnblogs.com/wangtanzhi/p/12243206.html 1:某些情况下绕过后缀名检测: ...

  8. jsch通过SSH2执行linux命令

    public class SSHUtils { private Channel channel; private Session session = null; private int timeout ...

  9. POJ - 3661 Running(dp---背包)

    题意:Bessie要运动N分钟,已知每一分钟可以跑的距离,每一分钟可选择跑或者不跑,若选择跑,疲劳度加1,但疲劳度不能超过M:若选择不跑,则每过一分钟,疲劳度减1,且只有当疲劳度减为0时可以继续跑.求 ...

  10. PAT Advanced 1115 Counting Nodes in a BST (30) [⼆叉树的遍历,BFS,DFS]

    题目 A Binary Search Tree (BST) is recursively defined as a binary tree which has the following proper ...