《Excel VBA与VSTO基础实战指南》属于学习Excel VBA的初中级教材,重点阐述了Excel VBA的基本理论、代码自动化以及开发Excel插件的思路。通读本书可以轻松应对制表工作中的疑难,同时还可以开发商业插件。
本书包括五部分内容,开头部分简述自动化操作的意义和成果展示;第二部分详细剖析VBA 的所有基础概念,包含代码的存放位置、写书方式、调用方式,认识对象、属性、方法与事件,以及理解变量、常量与数据类型并且掌握循环语句、条件语句、防错语句等知识;第三部分是VBA的高级应用,包含数组、窗体、字典、功能区设计、插件开发和撤销代码等知识;第四部分介绍通过VSTO开发Excel插件;第五部分提供365个VBA常见疑难解答。
本书每段代码都有思路分析,且对每句代码都提供了代码含义的详细注释,力求使讲解过程可
以更加精准,让代码更易理解,为读者提供更优秀的阅读体验。
实力作者第10本VBA图书上市,集VBA、VSTO及插件开发与一书,代码清晰,讲解详细
罗刚君,网名andysky,从事Excel研究及VBA二次开发10多年,擅长Excel函数、图表、透视表和VBA,尤其对Excel VBA有着相当丰富的开发经验和熟练的实战技能,也拥成丰硕的开发成果。
作者担任过近10个Excel相关论坛的版主,著有15本Excel图书,书名如下:
1.《Excel 2007 VBA范例大全》
2.《Excel 2007技法与行业应用实例精讲》
3.《Excel 2007 VBA开发技术大全》
4.《Excel 2007函数案例速查宝典》
5.《Excel VBA程序开发自学宝典》
6.《Excel 2010 VBA编程与实践》
7.《Excel 2010函数与图表速查手册》
8.《Excel VBA程序开发自学宝典(第2版)》
9.《Excel函数、图表与透视表从入门到精通》
10.《来吧!带你玩转Excel VBA》
11.《Excel VBA程序开发自学宝典(第3版)》
12.《Excel 2013函数案例自学宝典(实战版)》
13.《Excel 2013 VBA编程与实践》
14.《Excel 2016实用技巧自学宝典》
15.《Excel VBA与VSTO基础实战指南》
Microsoft Excel 是制表工具中最强大的软件,但是 Excel 内置的功能无法满足相对复杂的工作需求,而且不具备自动化操作的特性。在此前提下, VBA 应运而生, 它可以让复杂操作简单化,让烦琐工作自动化。
目前 Microsoft Office 已升级到 2016 版, Excel 自带的 VBA 版本为 7.1。本书以 Excel 2016为基础编写,但是由于 Excel 2010、 Excel 2013 和 Excel 2016 的 VBA 的差异微乎其微,小到可以忽略,因此读者也可以使用 Excel 2010、 Excel 2013 来学习本书的知识。
本书目的:
本书重点有两个,其一是普及 Excel VBA 基础知识,其二是开发 Excel 插件。本书用了超过 50%的篇幅阐述 Excel VBA 的基本概念与语法规则,力图使读者在强化编程理论知识的基础上再学习插件开发等进阶应用。在基础章节中,重点展示了过程、参数、变量、常量、数据类型、对象、属性、方法和事件等概念,并通过第 7 章和第 8 章的数十个案例印证这些理论的价值,以及调用思路。
本书从第 13 章开始,重点讲述开发 Excel 插件的知识和步骤,并提供了诸多模板供读者调用。 Excel 插件从大体上分为两类,其一是开源的加载宏文件,其二是受保护的加载项。加载宏通常为 xla 或者 xlam 格式,直接在 VBA 的代码编译器中编写,本书不仅详细演示了开发加载宏的所有步骤和思路,还提供了让插件执行后可以撤销的方法,让用户在使用过程中不用担心覆盖重要数据,从而提升插件的品质。
加载项通常是 DLL 格式,使用 VB 或者 VB.net 开发, VB 开发的插件无法用于 64 位的 Office软件,因此本书为读者展示了 VB.net 中的 Office 插件开发工具 VSTO 的应用。
VSTO 属于 Visual Studio 平台中的工具,本书以 Visual Studio 2015 为例,详细分析了 VSTO
与 VBA 代码的语法差异,并通过三个最具代表性的插件设计步骤演示利用 VSTO 封装代码的过程,同时也为读者提供诸多模板,让大家在实际工作中利用这些模板快速地设计出自己的插件。
本书结构:《Excel VBA 与 VSTO 基础实战指南》大体分为五部分:
第一部分包含第 1 章,主要说明 VBA 的价值,从而提升读者对 VBA 的学习热情与兴趣。
第二部分最重要,详细剖析了 VBA 的基础理论,包含第 2 章到第 9 章。此部分内容重点展示了 Excel VBA 的所有基础理论,包含代码的存放位置、输入代码的方式、调用代码的方式、如何让代码运行时畅通无阻,理解什么是过程、对象、参数、事件、属性、方法、变量、常量和数据类型,并逐一讲解了工作中最有用的条件语句、循环语句和防错语句的语法,同时提供了数十个案例来加深读者对这些基础理论的理解。
第三部分包含第 10 章到第 15 章,分别介绍了通过数组优化代码,利用字典去除重复值,以及设计功能区中的菜单的思路,并提供了大量的模板。最后讲解开发通用插件,并让插件在执行过程中可以撤销,这是本书的一大特色内容。
第四部分属于 VSTO 的应用,也就是利用 VB.net 来封装 VBA 代码,将它打包成受保护的安装程序,从而提升插件代码的安全性和专业性。
第五部分包含第 20 章,本章为读者提供 365 个 VBA 思考题目,并在赠送的案例文件中提供了答案。
本书特点:
相比同类书籍,本书在内容编排上具有以下特点:
1.本书对于 Excel VBA 的基础理论有着相当详细的讲解,包含 200 多页, 8 个章节。要学好编程必须基础理论掌握通透,否则编写三五年代码后仍然不能得心应手。基础理论是程序员十分重要的必备素质,而不应该只重实战轻理论。
2.目前国内 VBA 图书讲插件开发思路的书极少,而市场对插件的需求却极大,开发插件有较广阔的前景。本书不仅用较大的篇幅讲述插件开发相关的知识,而且加入了执行插件命令后可以撤销的设计思路,这在 VBA 图书市场上绝无仅有。
3.本书除 VBA 外,还提供 VSTO 知识,采用 VB.net 语法编写。
VSTO 比 VBA 更强大,能实现的功能也更多,同时还更安全。本书详细罗列了 VBA 与 VSTO在代码上的差异,然后演示修改 VBA 代码,使其符合 VB.net 语法规则的基本思路,从而让读者快速学会利用 VSTO 开发 Excel 插件。掌握本书第 16 章到第 19 章的知识,仅需半个月即可学会VSTO,不需要像学习 C#那样,耗费半年甚至一两年时间。
4.本书在每章末尾会提供 5 个思考题,最后一章再追加 365 个思考题,一共 460 个。期望读者通过这些题目扩展知识面,同时能加深对书中理论知识的印象。
5.本书提供读者交流群,读者购书后可以加群下载案例文件,同时可以在群里与作者交流,加快学习进度。
在第233页 8.4.3节
事件案例:显示活动工作表中的产量达标率的代码中用了函数CountA(Range(“B:B”))来计算B列数据的个数,作为除数,这就把B1单元格的文本数据也算进去了,造成计算结果错误,正确答案是90%。
直接执行“标签”后面的“代码2”
应该是“代码3”
Then MsgBox “当前表没有数值”
严格来说,应该用“数据”代替“数值”较好。
因为用CountA函数时,如果有文本数据,也是能算得的。
类似的在第262页第4行的“数值”,也是一样的问题。
“3个列表框控件”应修改为“3个文本框控件”
VS032: VBAk 窗体和控件 应该是 VBA 窗体和控件,多了一个k