Excel VBA中APPLICATION是什么意思

 我来答
huang1314wei
2016-10-14 · 知道合伙人软件行家
huang1314wei
知道合伙人软件行家
采纳数:1323 获赞数:5877
税畅核心工程师

向TA提问 私信TA
展开全部
Application对象是Microsoft Office Excel
2007对象模型中最高级别的对象,表示Excel程序自身。Application对象提供正在运行的程序的信息、应用于程序实例的选项以及实例中打开的当前对象。因为它是对象模型中最高的对象,Application对象也包含组成一个工作簿的很多部件,包括如工作簿、工作表集合、单元格以及这些对象所包含的数据等。
Application对象包括:
程序范围的设置和选项。这些选项大部分同“工具”菜单下的“选项”对话框里的内容相同。
顶级对象返回的方法,如ActiveCell、ActiveSheet等。
在下面几节里,你将通过使用VBA代码示例学习到一些Application对象中经常使用到的对象、方法和属性。关于Application对象模型所有成员的详细资料,请参考Application对象成员。

Application对象中其它对象的引用方法
你可以使用Application属性返回Application对象。获取一个Application对象后,如需访问它下面的对象,可以在对象模型层级中往下移动。下面示例设置一个工作表的第一个单元格内容为20。
Application.Workbooks(1).Worksheets(1).Cells(1,1)=20

要表示一个单元格,上面的代码示例从Application对象开始,移到第一个工作簿,再移到第一个工作表,最后到这个单元格。
下面示例在另一个Excel程序中创建一个Excel工作簿对象,然后打开一个工作簿。
Set xl=CreateObject("Excel.Sheet")
xl.Application.Workbooks.Open "newbook.xls"

不需要使用“Application”限定词,很多的属性和方法也可以直接被用来返回那些最常用的用户界面对象,如活动工作表
(ActiveSheet属性)。例如,除了使用Application.ActiveSheet.Name = “Monthly
Sales”,你也可以使用ActiveSheet.Name = “Monthly
Sales”。然而,当使用这个简便表示方法时必需小心,需要选择正确的对象。例如通过使用Worksheet对象的Activate方确定你选择了正确的工作簿和工作表后,你可以使用Cell(1,1)表示第一个单元格。
有几种情况你必需使用Application限定词。例如,OnTime对象(本文后面部分将讨论)需要这个限定词,还有程序窗口的Width和
Height属性。一般来说,用来处理Excel窗口的外观或影响程序全局行为的属性或方法需要使用Application限定词;例如,
DisplayFormlaBar属性用来显示或隐藏公式栏,Calculation方法也需要限定词。
Application对象集合
这一节详细介绍一些和Application对象相关的集合。
AddIns集合
AddIns集合表示所有当前加载的Excel Add-in。你可以像枚举其它对象一样在你的程序中列举出关于add-in的不同类型信息。下面的示例列举出当前加载到Excel中的Add-in的路径和名称。
Sub ListAddIns()
Dim myAddin As AddIn
For
Each myAddin In AddIns
MsgBox myAddin.FullName
Next
End
Sub

Columns和Rows集合
这两个集合表示活动工作簿中的列和行。分别使用它们选择指定的列和行。
Application.Columns(4).Select

这个语句选择D列,就像你通过点击用户界面中的列的顶部一样。
Application.Rows(5).Select

这个语句选择工作表中的第5行,就像你点击行的左边框一样。
Dialogs集合
Dialogs集合包括Excel程序中所有的对话框。将在本文中后面部分更详细地讨论Dialogs集合。
Sheets集合
Sheets集合返回指定或活动工作簿中所有工作表的集合。Sheets集合可以包含Chart或Worksheet对象。
下面示例打印出活动工作簿中所有的工作表。
Application.Sheets.PrintOut

这个示例循环工作簿中所有的工作表并打印出包含数据区域的任何工作表。
For iSheet = 1 To Application.Sheets.Count
If
Not IsEmpty(Application.Sheets(iSheet).UsedRange) Then
Application.Sheets(iSheet).PrintOut copies:=1
End
If
Next iSheet

Application对象的属性
有很多的属性可以用来访问Excel 2007程序的各种对象,多得不能记住或在这里全部讨论。幸运的是只有一部分是你可能经常使用的。
ActiveCell
ActiveChart
ActiveSheet
ActiveWindow
ActiveWorkbook
RangeSelection
Selection
StatusBar
ThisWorkbook
下面的内容演示这些常用属性的使用方法。
ActiveCell属性
Application对象的ActiveCell属性返回一个表示活动工作簿中活动工作表的活动单元格的Range对象。如果你没有指定对象限定词,这个属性返回活动窗口的活动单元格。
注意区别活动单元格和选择的单元格。活动单元格是当前选择中的一个单元格。选择(Selection)可能包括一个单元格集合,但只有其中一个是活动单元格。
下面的示例改变活动单元格的字体格式。注意为了确保你操作正确的单元格,工作表集合的Activate方法让Sheet1成为活动工作表。
Worksheets("Sheet1").Activate
With ActiveCell.Font
.Bold = True
.Italic = True
End
With

ActiveChart属性
ActiveChart属性返回表示活动图表的Chart对象,不管它是嵌入的图表还是图表工作表。在一个嵌入的图表被选择或激活时,它就是活动图表。下面的示例使用ActiveChart属性添加一个3维柱形图到月销售记录工作表中。
Sub AddChart()
Charts.Add
With ActiveChart
.ChartType = xl3DColumn
.SetSourceData Source:=Sheets("Sheet1").Range("B3:H15")
.Location Where:=xlLocationAsObject, Name:="Monthly Sales"
.HasTitle = True
.ChartTitle.Characters.Text = Monthly Sales by Category
End
With
End
Sub

ActiveSheet属性
ActiveSheet属性返回一个表示当前选中的工作表(顶部工作表)的Worksheet对象。在一个工作簿中只有一个工作表能成为活动工作表。下面的示例显示活动工作表的名称。
MsgBox "The name of the active sheet is " & ActiveSheet.Name

下面的示例将活动工作表复制用户指定的次数并放置在Sheet1之前。
Sub CopyActiveSheet()
Dim x As
Integer
x = InputBox("Enter number of times to copy active sheet")
For numtimes = 1 To x
' Put copies in front of Sheet1.
ActiveWorkbook.ActiveSheet.Copy _
Before:=ActiveWorkbook.Sheets("Sheet1")
Next
End
Sub

ActiveWindow属性
ActiveWindow属性返回一个表示活动窗口(顶部窗口)的Window对象。下面的示例显示活动窗口的名称(Caption属性)。
MsgBox "The name of the active window is " & ActiveWindow.Caption

Caption属性作为活动窗口的名称允许你通过使用友好的名称而不是序号来获得窗口。
下面的示例选择并打印一个工作表,然后对第二个工作表重复此过程。
Sub PrintWorksheet()
Application.ScreenUpdating = False
Sheets("Sales").Select
ActiveWindow.SelectedSheets.PrintOut Copies:=1, Collate:=True
Sheets("Expenses").Select
ActiveWindow.SelectedSheets.PrintOut Copies:=1, Collate:=True
End
Sub

在这个例子中,你可能疑惑为什么设置ScreenUpdating属性为False。当Excel执行一系列任务时,屏幕被更新并刷新很多次,这将导致屏幕闪烁。设置ScreenUpdating属性为False可以消除闪烁。另外,因为电脑处理器不需要暂停来刷新屏幕,这样也可以让大型程序运行得较快一点。
ActiveWorkbook属性
ActiveWorkbook属性返回一个表示活动窗口(顶部窗口)中的工作簿的Workbook对象。这个示例显示活动工作簿的名称。
MsgBox "The name of the active workbook is " & ActiveWorkbook.Name

下面示例设置计算模式为手动(这样其它工作簿将不计算),然后循环并计算活动工作簿的每个工作表。
Sub CalcBook()
Dim wks As Worksheet
Application.Calculation = xlManual
For
Each wks In ActiveWorkbook.Worksheets
wks.Calculate
Next
Set wks = Nothing
End
Sub

RangeSelection属性
RangeSelection属性返回一个表示指定窗口中工作表里选择的单元格的Range对象,即使在工作表中一个图表对象已经被选择或激活。这个示例显示活动窗口中工作表所选择单元格的地址。
MsgBox Application.ActiveWindow.RangeSelection.Address

当你选择了一个范围,RangeSelection属性和Selection对象表示同样一个范围。当你选择一个图表,RangeSelection属性返回之前选择的范围。Selection属性将在下一节中详细介绍。
这里介绍的语法RangeSelection.Name.Name在Office2003和2007中使用时都出现错误,如果该代码生效,必须先设置单元格A1的名称。并且应该不是单元格内容的前三个字符,而是名称的前三个字符。这应该是原文的疏漏。
下面的示例显示一个单元格中的前三个字符。
Range("A1").Select
MsgBox Left(ActiveWindow.RangeSelection.Name.Name, 3)

你可能奇怪为什么使用这样的语法
ActiveWindow.RangeSelection.Name.Name

当你选择一个范围,使用RangeSelection.Name方法可以获取像Sheet1!$A$1:$B$15这样的范围地址。另外,使用RangeSelection.Name.Name方法可以获取命名像MyRange1这样的范围本身的名称。
Selection属性
Selection属性返回活动窗口中被选择的对象。例如,对于单元格,这个属性返回Range对象;对于图表,它返回Chart对象。如果使用属性而没有对象限定符,等于使用Application.Selection。
这个示例清除Sheet1所选的内容。
Worksheets("Sheet1").Activate Selection.Clear

下面的例子将所选范围的总行数保存到变量NumRows。
NumRows = 0
For
Each area In Selection.Areas
NumRows = NumRows + area.Rows.Count
Next area

这个例子统计所选单元格的总数并在消息框中显示结果。
Sub Count_Selection()
Dim cell As
Object
Dim count As
Integer
count = 0
For
Each cell In Selection
count = count + 1
Next cell
MsgBox count & " item(s) selected"
End
Sub

StatusBar属性
StatusBar属性返回或设置状态栏的文本。这个属性允许你更改在Excel窗口底部的状态栏中显示的信息。它对在运算过程需要较长时间来完成时让用户知道正在运行的进度非常有帮助。
如果Excel控制状态栏时StatusBar属性返回False。另外,如需恢复默认状态栏文本,只需设置属性值为False即可;甚至在状态栏隐藏时也有效。
例如,使用下面的方式对每个处理的文件你可以给StatusBar属性赋值。
Dim FileNum As
Integer
FileNum = 0
For
Each file in Files
' Do something here.
Application.StatusBar = "Now processing File " & FileNum
FileNum = FileNum + 1
Next

然后当过程结束,你需要使用下面的语句将状态栏设置回正常状态。
Application.StatusBar = False

你可以创建你自己的过程使用StatusBar属性显示一个宏或其它过程的进度。
Sub ShowStatusBarProgress()
Dim i As
Long
Dim pctDone As
Double
Dim numSquares As
Long
Const MAXSQR As
Long = 15
For i = 1 To 30
pctDone = i / 30
numSquares = pctDone * MAXSQR
Application.StatusBar = Application.Rept(Chr(31), numSquares)
Application.Wait Now + TimeSerial(0, 0, 1)
Next i
Application.StatusBar = False
End
Sub

这个例子在状态栏上显示最大15个方块(由常数MAXSQR定义)。这个方块通过使用ASCII字符31来产生。这个缺少关于宏需要多长时间的视觉指示,它仅表明宏正在进行。Wait方法模拟一个宏需要长时间来执行。
ThisWorkbook属性
ThisWorkbook属性返回一个表示当前运行的宏代码所在工作簿的

Workbook对象。这个属性允许载入宏定义包含代码的工作簿。这种情况下ActiveWorkbook属性并不起作用,因为活动工作簿可能并不是包含载入宏代码的工作簿。换句话说,ActiveWorkbook属性不返回载入宏工作簿;它返回调用载入宏的工作簿。如果你使用你的Visual
Basic代码创建载入宏,你应该使用ThisWorkbook属性来限定任何必须运行在包含载入宏的工作簿上的语句。
下面示例关闭包含示例代码的工作簿。如果对工作簿的修改不被保存。
ThisWorkbook.Close SaveChanges:=False

下面的示例循环每个打开的工作簿并关闭它。然后关闭包含这个代码的工作簿。
Private oExcel As Excel.Application
Private wbk As Excel.Workbook
Sub CloseOpenWrkBks()
Dim wrkb As Workbook
For
Each wbk In Application.Workbooks
If wrkb.Name <> ThisWorkbook.Name Then
wbk.Close
True
End
If
Next wbk
ThisWorkbook.Close
True
End
Sub

Application对象方法
除了Application对象属性外,下面将介绍一些更加常用的方法。
FindFile方法和Dialogs集合
同GetOpenFilename方法不同,FindFile方法显示Open对话框并允许用户打开一个文件。如果新文件成功打开,此方法返回True。如果用户取消对话框,此方法返回False。
下面示例显示一个消息框提示用户打开一个指定文件,然后显示Open对话框。如果用户不能打开文件,显示一个消息框。
Sub OpenFile1( )
Dim bSuccess As
Boolean
Msgbox "Please locate the MonthlySales.xls file."
bSuccess = Application.FindFile
If
Not bSuccess Then
Msgbox "File not
open."
End
If
End
Sub

你也可以通过使用Dialogs集合细目的其中一个打开特别的对话框来完成同样的事情。使用Dialogs集合的一个好处是当你使用Show方法时,你可以传递参数给它来修改内置对话框的默认行为。例如,xlDialogOpen的参数有:file_text,
update_links, read_only, format, prot_pwd, write_res_pwd, ignore_rorec,
file_origin, custom_delimit, add_logical, editable, file_access,
notify_logical, converter.
注意:如需查找某个特定的对话框的参数,在Excel帮助文档的“内置对话框参数列表”中找到相应的对话框常数。
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式