分享
 
 
 

Excel 2007 VBA与宏完全剖析

Excel 2007 VBA与宏完全剖析  点此进入淘宝搜索页搜索
  特别声明:本站仅为商品信息简介,并不出售商品,您可点击文中链接进入淘宝网搜索页搜索该商品,有任何问题请与具体淘宝商家联系。
  參考價格: 点此进入淘宝搜索页搜索
  分類: 图书,计算机/网络,家庭与办公室用书,微软Office ,

作者: (美)杰莱(Jelen,B.),(美)斯太德(Syrstad,T.) 著,郭兵英 译

出 版 社: 人民邮电出版社

出版时间: 2008-7-1字数:版次: 1页数: 520印刷时间:开本: 16开印次:纸张:I S B N : 9787115178589包装: 平装编辑推荐

“在当今这个信息浩如烟海而时间弥足珍贵的时代、只有以简洁的方式快速获悉汇总数据,才能够让公司脱颖而出成为行业领头羊本书介绍的技巧将让您梦想成真 ”

——Jerry Kohl,Brighton Collectibles公司顾问

如果您是Excel专家,却发现宏录制器不起作用,且录制的代码让您一头雾水,则本书正是为您编写的。今天录制的宏可能在明天不起作用,也就是说,录制的宏可能能够处理包含14条记录的数据集,但无法处理包含12条或16条记录的数据集。这是宏录制器存在的常见问题,它们是导致众多Excel大师厌恶编写宏的罪魁祸首。

本书讨论宏录制器不起作用的原因。阐述如何对录制的代码进行修改,使其能够处理任何数据集。本书假设读者精通Excel,但不要求读者有任何编程经验。本书全面介绍了使用Exce1VBA自动生成报表和设计应用程序所需的技能,适合要自动生成报表或为他人设计功能齐全的应用程序的读者阅读。

学习VBA语法:

自动控制功能强大的Excel工具:数据透视表、图表和高级筛选;

自动完成重复的任务;

使用自定义对话框创建Excel应用程序;

快速生成数百个Exoel个报表;

了解Exce12007中的变化对VBA宏的影响。

学习经过实践检验的技巧,迅速提高使用VBA开发Excel宏的技能。

BilI Jelen,就是著名的M rExcel!他是业界领先的Excel网站M rExcel.com的负责人和Microsoft Excel的MVP。他在一家快速成长的计算机公司担任了12年的财务分析师,在此期间其Excel技能变得出神入化。只需凭借一个电子表格,他就能够在最短的时间内将数千行的交易数据变成有意义的摘要报告。Bill Jelen是一名卓有成就的Excel图书作者。还是加拿大电视节目的嘉宾。在世界各地的会计俱乐部常常能够见到Bill的身影,那是他正在举办幽默而内容丰富的Excel讲座。他的网站每年的访问量高达1200万次。

I racy Svrstad

是Excel和Access咨询师。作为MrExcel.corn顾问团队的一员。她帮助世界各地的客户开发VBA解决方案。她对以前为开发应用程序而学习VBA的艰辛仍记忆犹新。

内容简介

本书介绍了大量经过实践检验的Excel技巧,帮助读者迅速提高使用VBA开发Excel宏的技能,从而避免大量手工汇总数据和创建报表,节省用户宝贵的时间。

全书包含27章,详细介绍了以下内容:Excel宏录制器和VBA语法,引用区域,使用用户定义函数,循环和流程控制,RlC1公式,使用VBA自动控制Excel 2007新增功能,事件编程,使用用户窗体,创建图表,实现高级筛选,创建数据透视表,数据可视化和条件格式,检索Web数据,使用数组,读写文本文件,创建自定义对象和集合,使用WindowsAPI,处理错误,创建自定义选项卡和加载项。

本书语言简明清晰,内容实用,实例丰富,适合熟悉Excel并想自动完成日常工作或为他人创建Excel应用程序的人员阅读。

目录

第1章使用VBA发挥Excel的威力

1.1Excel的威力

1.2进入壁垒

1.3宏录制器不管用

1.3.1Visual Basic并不像BASIC

1.3.2 VBA非常容易上手

1.3.3 Excel VBA值得学习

1.4熟悉“开发工具”选项卡

1.5宏安全性

1.5.1添加受信任位置

1.5.2使用宏设置启用不在受信任位置的工作簿中的宏

1.5.3使用设置“禁用所有宏,并发出通知”

1.6录制和存储宏

1.7运行宏

1.7.1创建宏按钮

1.7.2将宏关联到窗体控件、文本框或形状

1.8使用Excel 2007新增的文件类型

1.9了解Visual Basic编辑器

1.9.1Visual Basic编辑器设置

1.9.2工程资源管理器

1.9.3属性窗口

1.10了解宏录制器的缺点

1.10.1准备录制宏

1.10.2录制宏

1.10.3在编程窗口中查看代码

1.10.4其他时间运行该宏时得到意外的结果

1.10.5一种可能的解决方案:在录制时使用相对引用

第2章VBA简介

2.1VBA是一种面向对象语言

2.2VBA语言的组成部分

2.3VBA学起来并不难

2.3.1VBA帮助文件-使用F1键获取帮助

2.3.2使用帮助主题

2.4查看录制的宏代码——使用Visual Basic编辑器和帮助

2.4.1可选参数

2.4.2预定义常量

2.4.3可返回对象的属性

2.5使用调试工具帮助理解录制的代码

2.5.1步进执行代码

2.5.2另一个调试选项——断点

2.5.3在代码中向前或向后移动

2.5.4不逐句运行每行代码

2.5.5在逐句执行代码时进行查询

2.5.6使用监视设置断点

2.5.7监视对象

2.6所有对象、方法和属性的终极参考信息

2.7整理代码的5项技巧

2.7.1技巧1:不要选择任何单元格

2.7.2技巧2:从区域底部开始查找最后一行

2.7.3技巧3:使用变量避免硬编码行和公式

2.7.4技巧4:在一条语句中进行复制和粘贴

2.7.5技巧5:使用WithEnd With对相同的单元格或区域执行多项操作

2.8综合应用——修复录制的代码

第3章引用区域

3.1Range对象

3.2使用选择的左上角和右下角指定区域

3.3命名区域

3.4引用区域的快捷方式

3.5引用其他工作表中的区域

3.6引用相对于其他区域的区域

3.7使用Cells属性选择区域

3.8使用Offset属性引用区域

3.9使用Resize属性修改区域的大小

3.10使用Columns和Rows属性指定区域

3.11使用Union方法合并多个区域

3.12使用Intersect方法根据重叠区域创建新区域

3.13使用IsEmpty函数检查单元格是否为空

3.14使用CurrentRegion属性快速选择数据区域

3.15使用区域集合返回非连续区域

3.16引用数据表

第4章用户定义的函数

4.1创建用户定义的函数

4.2自定义函数示例

4.3共享UDF

4.4很有用的自定义函数

4.4.1获取工作簿的名称

4.4.2获取当前工作簿的名称和文件路径

4.4.3检查工作簿是否打开

4.4.4检查工作表是否包含在打开的工作簿中

4.4.5统计文件夹中的工作簿数量

4.4.6获取UserID

4.4.7检索最后一次保存的日期和时间

4.4.8获取固定不变的日期和时间

4.4.9验证电子邮件地址

4.4.10根据内部颜色对单元格求和

4.4.11统计非重复值的数量

4.4.12删除区域中重复的值

4.4.13在区域中查找第一个非空单元格

4.4.14替换多个字符

4.4.15从文本中获取数字

4.4.16将星期编号转换为日期

4.4.17从用分隔符分隔的字符串中提取值

4.4.18排序并拼接

4.4.19对数字和字母进行排序

4.4.20在文本中搜索字符串

4.4.21颠倒单元格内容的顺序

4.4.22多个最大值

4.4.23返回链接的地址

4.4.24返回单元格地址的列字母

4.4.25静态随机

4.4.26将Select Case用于工作表

第5章循环和流程控制

5.1ForNext循环

5.1.1在For语句中使用变量

5.1.2ForNext循环的变体

5.1.3在满足特定条件时提早退出循环

5.1.4嵌套循环

5.2Do循环

5.2.1在D0循环中使用While或Until子句

5.2.2While...Wend循环

5.3 VBA循环:For Each

5.3.1对象变量

5.3.2遍历文件夹中的所有文件

5.4流程控制:使用If...The Else和Select Case

5.4.1基本流程控制:If...The Else

5.4.2条件

5.4.3If...The ElseEnd If

5.4.4使用IfElse IfEnd If检测多个条件

5.4.5使用Select CaseEnd Select检测多个条件

5.4.6在Case语句中使用复杂表达式

5.4.7嵌套If语句

第6章R1C1公式

6.1引用单元格:A1和R1C1引用样式之比较

6.2切换到R1C1引用样式

6.3Excel公式创造的奇迹

6.3.1输入公式一次并复制多次

6.3.2逮并不神奇

6.3.3在VBA中采用A1与RIC1样式之比较

6.4R1C1引用样式简介

6.4.1使用R1C1相对引用

6.4.2使用R1C1绝对引用

6.4.3使用R1C1混合引用

6.4.4使用R1C1引用样式整行或整列

6.4.5使用单个R1C1公式替换多个A1公式

6.4.6记住列字母对应的列号

6.5条件格式必须使用R1C1引用

6.5.1通过用户界面设置条件格式

6.5.2使用VBA设置条件格式

6.5.3找出G列中最大的值

6.6数组公式必须是R1C1公式

第7章Excel 2007新增和修改过的功能

7.1如果Excel用户界面不同,则VBA也不同

7.1.1选项卡

7.1.2图表

7.1.3数据透视表

7.1.4条件格式

7.1.5数据表

7.1.6排序

7.1.7SinartArt

7.2宏录制器不记录在以前的版本中记录的操作

7.3学习新的对象和方法

7.4兼容模式

7.4.1Version

7.4.2Excel8CompatibilityMode

第8章使用VBA创建和操作名称

8.1Excel名称

8.2全局名称和局部名称

8.3添加名称

8.4删除名称

8.5添加备注

8.6名称类型

8.6.1公式

8.6.2字符串

8.6.3数字

8.6.4数据表

8.6.5让名称指向数组

8.6.6保留名称

8.7隐藏名称

8.8确定名称是否存在

第9章事件编程

9.1事件级别

9.2使用事件

9.2.1事件参数

9.2.2启用事件

9.3工作簿事件

9.3.1Workbook Activate()

9.3.2Workbook Deactivate()

9.3.3Workbook_Open()

9.3.4Workbook BeforeSave(ByVal SaveAsUI As Boolean,Cancel As Boolean)

9.3.5Workbook_BeforePrint(Cancel As Boolean)

9.3.6Workbook BeforeClose(Cancel As Boolean)

9.3.7Workbook_NewSheet(ByVal Sh As Object)

9.3.8Workbook_WindowResize(ByVal Wn As Window)

9.3.9Workbook_WindowActivate(ByVal Wn As Window)

9.3.10Workbook_WindowDeactivate(ByVal WnAs Window)

9.3.11Workbook_AddlnInstall()

9.3.12Workbook_AddlnUninstall

9.3.13Workbook_SheetActivate(ByVal ShAs Object)

9.3.14Workbook_SheetBeforeDoubleClick (ByVal Sh As Object, ByVal Target As Range, Cancel As Boolean)

9.3.15Workbook_SheetBeforeRightClick(ByVal Sh As Object, ByVal Target As Rnge, Cancel As Boolean)

9.3.16Workbook_SheetCalculate(ByVal ShAs Object)

9.3.17Workbook_SheetChange (ByVal Sh As Object, ByVal Target As Range)

9.3.18Workbook_Sync(ByVal SyncEventType As Office.MsoSyncEventType)

9.3.19Workbook_SheetDeactivate(ByVal Sh As Object)

9.3.20Workbook_SheetFollowHyperlink (ByVal Sh As Object, ByVal Target As Hyperlink)

9.3.21Workbook_SheetSelectionChange(ByVal Sh As Object, ByVal Target As Range)

9.3.22Workbook PivotTableCloseConnection(ByVal Target As PivotTable)

9.3.23Workbook_PivotTableOpenConnection(ByVal Target As PivotTable)

9.3.24Workbook RowsetComplete(ByVal Description As String, ByVal Sheet As String, ByVal Success As Boolean)

9.4工作表事件

9.4.1Worksheet_Activate()

9.4.2Worksheet_Deactivate()

9.4.3Worksheet BeforeDoubleClick(ByVal Target As Range, Cancel As Boolean)

9.4.4Worksheet BeforeRightClick(ByVal Target As Range, Cancel As Boolean)

9.4.5Worksheet_Calculate0

9.4.6Worksheet Change(ByVal Target As Range)

9.4.7Worksheet_SelectionChange(ByVal Target As Range)

9.4.8Worksheet_FollowHyperlink(ByVal Target As tfyperlink)

9.5在单元格中快速输入24小时制事件

9.6图表事件

9.6.1嵌入图表

9.6.2Chart_Activate()

9.6.3Chart BeforeDoubleClick(ByVal ElementlD As Long, ByVal Argl As Long,ByVal Arg2 As Long, Cancel As Boolean)

9.6.4Chart BeforeRightClick(Cancel As Boolean)

9.6.5Chart_Calculate()

9.6.6Chart_Deactivate()

9.6.7Ehart_MouseDown(ByVal Button As Long, ByVal Shift As Long, ByVal x As Long, ByVal y As Long)

9.6.8Chart MouseMove(ByVal Button As Long, ByVal Shift As Long, ByVal x As Long, ByVal y As Long)

9.6.9Chart_MouseUp(ByVal Button As Long, ByVal Shift As Long, ByVal x As Long, ByVal y As Long)

9.6.10Chart Resize()

9.6.11Chart_Select(ByVal ElementID As Lon9,ByVal Argl As Lon9,ByVal Ar92 As Long

9.6.12Chart_SeriesChange(ByVal SeriesIndex As Lon9,ByVal PointIndex As Long)

9.6.13Chart_DragOver()

9.6.14Chart_DragPlot()

9.7应用程序级事件

9.7.1AppEvent_AflerCalculate0

9.7.2AppEventNewWorkbook(ByVal Wb As Workbook、

9.7.3AppEvent_SheetActivate(ByVal Sh As Object)

9.7.4AppEvent_SheetBeforeDoubleClick(ByVal Sh As Object.ByVal Target As Range,Cancel As Boolean)

9.7.5AppEvent SheetBeforeRightClick(ByVal Sh As Object,ByVal Target As nge,Cancel As Boolean)

9.7.6AppEvent SheetCalculate(ByVal Sh As Object)‘

9.7.7AppEvent_SheetChange(ByVal Sh As Object,ByVal Target As Range)

9.7.8AppEvent_SheetDeactivate(ByVal Sh As Object)‘

9.7.9AppEvent_SheetFollowHyperlink(ByVal Sh As Object.ByVal Target As Hyperlink)

9.7.10AppEvent_SheetSelectionChange(ByVal ShAs Object.ByVal Target As Range)

9.7.11AppEvent_WindowActivate(ByVal Wb As Workbook,ByVal Wn As Window)

9.7.12AppEvent_WindowDeactivate(ByVal Wb As Workbook,ByVal Wn As Window

9.7.13AppEvent_WindowResize(ByVal Wb As Workbook.ByVal Wn As Window)

9.7.14AppEvent_WorkbookActivate(ByVal WbAs Workbook)

9.7.15AppEvent WorkbookAddinInstall(ByVal WbAs Workbook)

9.7.16AppEvent_WorkbookAddinUninstall(ByVal WbAs Workbook、

9.7.17AppEvent WorkbookBeforeClose(ByVal Wb As Workbook.Cancel As Boolean ByVal Target As PivotTable)

9.7.18AppEvent_WorkbookBeforePrint(ByVal Wb As Workbook.Cancel As Boolean)

9.7.19AppEvent_WorkbookBeforeSave(ByVal Wb As Workbook.Byval SaveAsUI As Boolean,Cancel As Boolean)

9.7.20AppEvent WorkbookNewSheet(ByVal Wb As Workbook.ByVal Sh As Object

9.7.21AppEvent_WorkbookOpen(ByVal Wb As Workbook)

9.7.22AppEvent_WorkbookPivotTableCloseConnection(ByVal Wb As Workbook.ByVal Target As PivotTable)

9.7.23AppEvent_WorkbookPivotTableOpenConnection(ByVal Wb As Workbook.

9.7.24AppEvent_WorkbookRowsetComplete(ByVal Wb As Workbook, ByVal Description As String, ByVal Sheet As String, ByVal Success As Boolean)

9.7.25AppEvent WorkbookSync(ByVal Wb As Workbook, ByVal SyncEventType As Office.MsoSyncEventType)

第10章用户窗体简介

第11章创建图表

第12章使用统计函数

第13章使用VBA创建数据透视表

第14章展示Excel的威力

第15章数据可视化和条件格式

第16章读写Web

第17章Excel 2007中的XML

第18章自动控制Word

第19章数组

第20章处理文本文件

第21章将Access用作后端以及改善多用户数据访问

第22章创建类、记录和集合

第23章高级用户窗体技术

第24章Windows应用程序编程接口

第25章处理错误

第26章创建自定义选项卡方便用户运行宏

第27章创建加载项

书摘插图

第1章使用VBA发挥Excel的威力

1.1Excel的威力

结合使用Visual Basic for Applications(VBA)和Microsoft Excel可能是最强大的工具,该工具就位于5亿Microsoft Office用户的桌面上,但大多数用户并不知道如何发挥Excel VBA的威力。通过使用VBA,可更快地在Excel中完成各种任务。如果读者定期使用Excel生成一系列的月度图表,可让VBA帮助完成这种任务,这只需几秒钟。

1.2进入壁垒

要成功地学习VBA编程,将遇到两个壁垒:首先,Excel的宏录制器存在缺陷,无法生成可作为模型使用的代码;其次,对于学习过编程语言(如Basic)的用户来说,VBA的语法难以理解。

1.3宏录制器不管用

Microsoft在20世纪90年代开始占领电子表格市场。虽然他们在建立功能强大的电子表格程序让Lotus 1-2-3用户可轻松过渡方面取得了巨大成功,但其宏语言截然不同,精通录制Louts 1-2-3宏的用户在尝试录制Excel宏时将遇到困难。虽然Microsoft VBA编程语言的功能远远超过了Lotus 1-2-3的宏语言,但一个重要的缺陷是宏录制品不管用。

……

Excel 2007 VBA与宏完全剖析

 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
>>返回首頁<<
 
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有