借助VBA成为Excel高级用户 学习运用VBA语言的强大功能,将自己的Excel技能提升到全新水平!综合性指南 中文版Excel 2016高级VBA编程宝典(第8版) 将帮助你实现数据处理自动化,并开发出功能完备的Excel程序。本书针对Excel版本做了更新,内容新颖,助你开发大型和小型Excel应用。 本书直抒主题,以读者为中心,摒弃华而不实的、冗长的解释,呈现紧贴实用的示例、注意事项和诀窍,提供大量代码和示例模板,助你从普通数据分析人员蜕变为Excel编程专家。
本书针对Excel版本做了更新,内容新颖,助你开发大型和小型Excel应用。本书直抒主题,以读者为中心,摒弃华而不实的、冗长的解释,呈现紧贴实用的示例、注意事项和诀窍,提供大量代码和示例模板,助你从普通数据分析人员蜕变为Excel编程专家。
Michael Alexander是微软认证的应用开发人员,已撰写多本Microsoft Access和Excel书籍。Michael的个人网站是datapigtechnologies.com。Dick Kusleika在最近15年的时间里,一直通过在线论坛、博客、图书和会议等渠道传播知识,帮助用户深入了解和限度地运用Microsoft Offi ce产品。
第Ⅰ部分 Excel VBA基础知识
第1章 电子表格应用开发入门 3
1.1 关于电子表格应用 3
1.2 应用开发的步骤 4
1.3 确定用户的需求 4
1.4 对满足这些需求的应用
进行规划 5
1.5 确定最适用的用户界面 6
1.5.1 自定义功能区 7
1.5.2 自定义快捷菜单 7
1.5.3 创建快捷键 7
1.5.4 创建自定义对话框 8
1.5.5 在工作表中使用
ActiveX控件 8
1.5.6 开始开发工作 10
1.6 关注最终用户 10
1.6.1 测试应用 10
1.6.2 应用的安全问题 11
1.6.3 如何让应用程序看起来更
简明美观 13
1.6.4 创建用户帮助系统 13
1.6.5 将开发成果归档 14
1.6.6 给用户应用程序 14
1.6.7 在必要时对应用进行更新 14
1.7 其他开发问题 14
1.7.1 用户安装的Excel版本 15
1.7.2 语言问题 15
1.7.3 系统速度 15
1.7.4 显示模式 15
第2章 VBA概述 17
2.1 宏录制器 17
2.1.1 创建你的及时个宏 17
2.1.2 比较宏录制的模式和
相对模式 20
2.1.3 关于宏录制的其他概念 24
2.2 Visual Basic编辑器概述 28
2.2.1 了解VBE组件 28
2.2.2 使用工程资源管理器 29
2.2.3 使用代码窗口 31
2.2.4 自定义VBA环境 33
2.2.5 “编辑器格式”选项卡 34
2.2.6 “通用”选项卡 35
2.2.7 “可连接的”选项卡 35
2.3 VBA的基础知识 36
2.3.1 了解对象 36
2.3.2 了解集合 37
2.3.3 了解属性 37
2.4 使用Range对象 40
2.4.1 找到Range对象的属性 41
2.4.2 Range属性 41
2.4.3 Cells属性 42
2.4.4 Offset属性 44
2.5 需要记住的基本概念 45
2.6 学习更多信息 46
2.6.1 阅读本书剩余的章节 47
2.6.2 让Excel来帮助编写宏 47
2.6.3 使用帮助系统 47
2.6.4 使用对象浏览器 47
2.6.5 从网上获取 48
2.6.6 利用用户论坛 49
2.6.7 访问专家博客 49
2.6.8 通过YouTube查找视频 50
2.6.9 通过Microsoft OfficeDev
Center获取信息 50
2.6.10 解析其他的Excel文件 50
2.6.11 咨询周围的Excel人才 50
第3章 VBA编程基础 51
3.1 VBA语言元素概览 51
3.2 注释 53
3.3 变量、数据类型和常量 54
3.3.1 定义数据类型 55
3.3.2 声明变量 56
3.3.3 变量的作用域 58
3.3.4 使用常量 61
3.3.5 使用字符串 62
3.3.6 使用日期 62
3.4 赋值语句 63
3.5 数组 65
3.5.1 声明数组 66
3.5.2 声明多维数组 66
3.5.3 声明动态数组 66
3.6 对象变量 67
3.7 用户自定义的数据类型 68
3.8 内置函数 69
3.9 处理对象和集合 71
3.9.1 With-End With结构 72
3.9.2 For Each-Next结构 72
3.10 控制代码的执行 74
3.10.1 GoTo语句 74
3.10.2 If-Then结构 75
3.10.3 Select Case结构 78
3.10.4 指令块的循环 82
第4章 VBA的子过程 89
4.1 关于过程 89
4.1.1 子过程的声明 90
4.1.2 过程的作用域 90
4.2 执行子过程 91
4.2.1 通过“运行子过程/用户
窗体”命令执行过程 92
4.2.2 从“宏”对话框执行过程 92
4.2.3 用Ctrl 快捷键组合
执行过程 93
4.2.4 从功能区执行过程 94
4.2.5 从自定义快捷菜单中
执行过程 94
4.2.6 从另一个过程中执行过程 95
4.2.7 通过单击对象执行过程 98
4.2.8 在事件发生时执行过程 99
4.2.9 从“立即窗口”执行过程 100
4.3 向过程中传递参数 100
4.4 错误处理技术 103
4.4.1 捕获错误 104
4.4.2 错误处理示例 105
4.5 使用子过程的实际示例 108
4.5.1 目标 108
4.5.2 工程需求 108
4.5.3 已经了解的信息 108
4.5.4 解决方法 109
4.5.5 初步的录制工作 109
4.5.6 初始设置 111
4.5.7 代码的编写 112
4.5.8 排序过程的编写 112
4.5.9 更多测试 116
4.5.10 修复问题 117
4.5.11 实用程序的可用性 120
4.5.12 对工程进行评估 121
第5章 创建函数过程 123
5.1 子过程与函数过程的比较 123
5.2 为什么创建自定义的函数 124
5.3 自定义函数示例 124
5.3.1 在工作表中使用函数 125
5.3.2 在VBA过程中使用函数 125
5.3.3 分析自定义函数 126
5.4 函数过程 128
5.4.1 函数的作用域 129
5.4.2 执行函数过程 129
5.5 函数过程的参数 131
5.6 函数示例 132
5.6.1 无参数的函数 132
5.6.2 带有一个参数的函数 134
5.6.3 带有两个参数的函数 136
5.6.4 使用数组作为参数的函数 137
5.6.5 带有可选参数的函数 138
5.6.6 返回VBA数组的函数 140
5.6.7 返回错误值的函数 142
5.6.8 带有不定数量参数的函数 144
5.7 模拟Excel的SUM函数 145
5.8 扩展后的日期函数 148
5.9 函数的调试 149
5.10 使用“插入函数”对话框 150
5.10.1 使用MacroOptions方法 151
5.10.2 指定函数类别 152
5.10.3 手动添加函数说明 153
5.11 使用加载项存储自定义函数 154
5.12 使用Windows API 154
5.12.1 Windows API示例 155
5.12.2 确定Windows目录 155
5.12.3 检测Shift键 157
5.12.4 了解有关API函数的
更多信息 158
第6章 了解Excel事件 159
6.1 Excel可以监视的事件类型 159
6.1.1 了解事件发生的顺序 160
6.1.2 存放事件处理程序的位置 160
6.1.3 禁用事件 161
6.1.4 输入事件处理代码 162
6.1.5 使用参数的事件处理程序 163
6.2 工作簿级别的事件 165
6.2.1 Open事件 165
6.2.2 Activate事件 166
6.2.3 SheetActivate事件 166
6.2.4 NewSheet事件 167
6.2.5 BeforeSave事件 167
6.2.6 Deactivate事件 167
6.2.7 BeforePrint事件 168
6.2.8 BeforeClose事件 169
6.3 检查工作表事件 171
6.3.1 Change事件 171
6.3.2 监视特定单元格区域的
修改 172
6.3.3 SelectionChange事件 177
6.3.4 BeforeDoubleClick事件 177
6.3.5 BeforeRightClick事件 178
6.4 监视应用程序事件 179
6.4.1 启用应用程序级别的事件 180
6.4.2 确定工作簿何时被打开 180
6.4.3 监视应用程序级别的事件 181
6.5 访问与对象无关联的事件 182
6.5.1 OnTime事件 182
6.5.2 OnKey事件 184
第7章 VBA编程示例与技巧 189
7.1 通过示例学习 189
7.2 处理单元格区域 190
7.2.1 复制单元格区域 190
7.2.2 移动单元格区域 191
7.2.3 复制大小可变的
单元格区域 191
7.2.4 选中或者识别各种类型的
单元格区域 193
7.2.5 调整单元格区域大小 194
7.2.6 提示输入单元格中的值 195
7.2.7 在下一个空单元格中
输入一个值 196
7.2.8 暂停宏的运行以便获得
用户选中的单元格区域 197
7.2.9 计算选中单元格的数目 199
7.2.10 确定选中的单元格
区域的类型 199
7.2.11 有效地循环遍历选中的
单元格区域 201
7.2.12 删除所有空行 204
7.2.13 任意次数地复制行 205
7.2.14 确定单元格区域是否包含
在另一个单元格区域内 206
7.2.15 确定单元格的数据类型 207
7.2.16 读写单元格区域 208
7.2.17 在单元格区域中写入值的
更好方法 209
7.2.18 传递一维数组中的内容 211
7.2.19 将单元格区域传递给
Variant类型的数组 211
7.2.20 按数值选择单元格 212
7.2.21 复制非连续的单元格
区域 213
7.3 处理工作簿和工作表 215
7.3.1 保存所有工作簿 215
7.3.2 保存和关闭所有工作簿 216
7.3.3 隐藏除选区之外的区域 216
7.3.4 创建超链接内容表 217
7.3.5 同步工作表 218
7.4 VBA技巧 219
7.4.1 切换布尔类型的属性值 219
7.4.2 显示日期和时间 220
7.4.3 显示友好时间 222
7.4.4 获得字体列表 223
7.4.5 对数组进行排序 224
7.4.6 处理一系列文件 225
7.5 用于代码中的一些有用函数 227
7.5.1 FileExists函数 227
7.5.2 FileNameOnly函数 227
7.5.3 PathExists函数 228
7.5.4 RangeNameExists函数 228
7.5.5 SheetExists函数 229
7.5.6 WorkbookIsOpen函数 229
7.5.7 检索已经关闭的
工作簿中的值 230
7.6 一些有用的工作表函数 231
7.6.1 返回单元格的格式信息 232
7.6.2 会说话的工作表 233
7.6.3 显示保存或打印文件的
时间 233
7.6.4 理解对象的父对象 234
7.6.5 计算介于两个值之间的
单元格数目 235
7.6.6 确定行或列中一个
非空的单元格 236
7.6.7 字符串与模式匹配 237
7.6.8 从字符串中提取
第n个元素 238
7.6.9 拼写出数字 239
7.6.10 多功能函数 240
7.6.11 SHEETOFFSET函数 240
7.6.12 返回所有工作表中的
较大值 241
7.6.13 返回没有重复随机整数
元素的数组 242
7.6.14 随机化单元格区域 244
7.6.15 对单元格区域进行排序 245
7.7 Windows API调用 246
7.7.1 理解API声明 246
7.7.2 确定文件的关联性 247
7.7.3 确定默认打印机的信息 248
7.7.4 确定视频显示器的信息 249
7.7.5 读写注册表 250
第Ⅱ部分 高级VBA技术
第8章 使用透视表 255
8.1 数据透视表示例 255
8.1.1 创建数据透视表 256
8.1.2 检查录制的数据
透视表代码 257
8.1.3 整理录制的数据
透视表代码 258
8.2 创建更复杂的数据透视表 260
8.2.1 创建数据透视表的代码 261
8.2.2 更复杂数据透视表的
工作原理 262
8.3 创建多个数据透视表 263
8.4 创建转换的数据透视表 266
第9章 使用图表 269
9.1 关于图表 269
9.1.1 图表的位置 269
9.1.2 宏录制器和图表 270
9.1.3 Chart对象模型 270
9.2 创建嵌入式图表 271
9.3 在图表工作表上创建图表 273
9.4 修改图表 273
9.5 使用VBA激活图表 274
9.6 移动图表 275
9.7 使用VBA使图表取消激活 276
9.8 确定图表是否被激活 276
9.9 从ChartObjects或Charts
集合中删除图表 277
9.10 循环遍历所有图表 277
9.11 调整ChartObjects对象的
大小并对齐 280
9.12 创建大量图表 281
9.13 导出图表 283
9.14 修改图表中使用的数据 285
9.14.1 基于活动单元格修改
图表数据 286
9.14.2 用VBA确定图表中
使用的单元格区域 287
9.15 使用VBA在图表上显示
任意数据标签 289
9.16 在用户窗体中显示图表 292
9.17 理解图表事件 295
9.17.1 使用图表事件的一个
示例 295
9.17.2 为嵌入式图表启用事件 298
9.17.3 示例:在嵌入式图表上
使用图表事件 299
9.18 VBA制图技巧 301
9.18.1 在整个页面上打印
嵌入式图表 301
9.18.2 创建未链接的图表 301
9.18.3 用MouseOver事件
显示文本 303
9.18.4 滚动图表 305
9.19 使用迷你图 307
第10章 与其他应用程序的交互 311
10.1 了解Microsoft Office
自动化 311
10.1.1 了解绑定概念 311
10.1.2 一个简单的自动化示例 313
10.2 从Excel中自动执行
Access任务 314
10.2.1 从Excel中运行
Access查询 314
10.2.2 从Excel运行Access宏 315
10.3 从Excel自动执行Word任务 316
10.3.1 将Excel数据传递给
Word文档 316
10.3.2 模拟Word文档的邮件
合并功能 31
书籍纸张不错,是正版。内容也比较全面,慢慢学习吧。
帮别人买的,见到有优惠就买了。
ok ok ok
纸张很好很好
物流3天到手,拿到后皱褶且塑封包装破坏,像旧的书一样,感觉很糟糕。并不是很愉快的购物体验。
有时间好好学习一下excel,工作中太有用了
纸张很好!
纸张很好!
还行,内容很翔实
非常不错的书
可以当工具书书用,如果弄透了就的会飞天
不错不错不错不错不错不错不错不错不错不错不错不错不错不错不错不错不错不错不错