5.1鸟瞰Application对象

5.2 必须了解的面向显示特性

5.2.1 使用ScreenUpdating改进和完善执行性能

代码清单5.1:实现屏幕更新的性能

'代码清单5.1: 实现屏幕更新的特性
Sub TimeScreenUpdating()
Dim dResult As Double 'test with screen updating turned on
dResult = TestScreenUpdating(True)
MsgBox Format(dResult, "0.00") & " seconds.", vbOKOnly 'test with screen updating turned off
dResult = TestScreenUpdating(False)
MsgBox Format(dResult, "0.00") & " seconds.", vbOKOnly End Sub Function TestScreenUpdating(bUpdatingOn As Boolean) As Double 'record the start time
Dim dStart As Double
dStart = Timer 'turn screen updating on or off
Application.ScreenUpdating = bUpdatingOn 'loop through each worksheet
'in the workbook 250 times
Dim nRepetition As Integer
Dim ws As Worksheet
For nRepetition = To
For Each ws In ThisWorkbook.Worksheets
ws.Activate
Next
Next 'turn screen updating on
Application.ScreenUpdating = True 'return elapsed time since procedure started
TestScreenUpdating = Timer - dStart 'clean up
Set ws = Nothing End Function

5.2.2 使用状态栏为最终用户提供信息

代码清单5.2:使用StatusBar属性显示信息

'代码清单5.2: 使用StatusBar属性显示信息
'this subroutine tests the impact of
'using statusbar to display lots of frequent messages.
Sub TimeStatusBar()
Dim dStart As Double
Dim dResult As Double
Dim bDisplayStatusBar As Boolean 'remember original status bar setting
bDisplayStatusBar = Application.DisplayStatusBar
'turn on the status bar
Application.DisplayScrollBars = True 'baseline test - no status bar, every row
'to isolate how long it takes to
'perform mod statement on all rows
dStart = Timer
TestStatusBar , False
dResult = Timer - dStart
MsgBox Format(dResult, "0.00") & " Seconds.", vbOKOnly 'time using statusbar -every row
dStart = Timer
TestStatusBar , True
dResult = Timer - dStart
MsgBox Format(dResult, "0.00") & " Seconds.", vbOKOnly 'time using statusbar -every fifth row
dStart = Timer
TestStatusBar , True
dResult = Timer - dStart
MsgBox Format(dResult, "0.00") & " Seconds.", vbOKOnly 'restore the status bar to its original setting
Application.DisplayScrollBars = bDisplayStatusBar End Sub 'this subroutine displays a message to the status bar
'(if desired) for each row in a worksheet using the
'interval specified.
Private Sub TestStatusBar(nInterval As Integer, bUseStatusBar As Boolean)
Dim lRow As Long
Dim lLastRow As Long
Dim ws As Worksheet 'using the first worksheet in this workbook
'no changes will be made to the worksheet.
Set ws = ThisWorkbook.Worksheets() 'every version since excel 97 has had
'65,536 rows. excel 5 had 16,384 rows.
lLastRow = ws.Rows.Count For lRow = To lLastRow 'test to see if the current row
'is the interval specified.
If lRow Mod nInterval = Then
If bUseStatusBar Then
Application.StatusBar = "processing row: " & lRow & _
" of " & lLastRow & " rows."
End If
End If
Next Application.StatusBar = False
Set ws = Nothing
End Sub

5.3 需要了解的面向显示特性

代码清单5.3:带有Cursor属性的可用光标

'代码清单5.3: 带有Cursor属性的可用光标
Sub ViewCursors()
Application.Cursor = xlNorthwestArrow
MsgBox "Do you like the xlNorthwestArrow? Hover over the worksheet to see it." Application.Cursor = xlIBeam
MsgBox "How about xlIBeam? Hover over the worksheet to see it." Application.Cursor = xlWait
MsgBox "How about xlWait? Hover over the worksheet to see it." Application.Cursor = xlDefault
MsgBox "How about xlDefault? Hover over the worksheet to see it." End Sub

代码清单5.4:示范各种面向窗口的属性

'代码清单5.4: 示范各种面向窗口的属性
Sub GetWindowInfo()
Dim lState As Long
Dim sInfo As String
Dim lResponse As Long 'Determine window state
lState = Application.WindowState
Select Case lState
Case xlMaximized
sInfo = "Window is maximized." & vbCrLf
Case xlMinimized
sInfo = "Window is maximized." & vbCrLf
Case xlNormal
sInfo = "window is normal." & vbCrLf
End Select 'prepare message to be displayed
sInfo = sInfo & "Usable Height = " & Application.UsableHeight & vbCrLf
sInfo = sInfo & "Usable Width = " & Application.UsableWidth & vbCrLf
sInfo = sInfo & "Height = " & Application.Height & vbCrLf
sInfo = sInfo & "Width = " & Application.Width & vbCrLf & vbCrLf sInfo = sInfo & "Would you like to minimize it? " & vbCrLf 'Display message
lResponse = MsgBox(sInfo, vbYesNo, "") 'Minimize window if user clicked yes
If lResponse = vbYes Then
Application.WindowState = xlMinimized
End If End Sub

5.4 便捷的Excel对象属性

属性 返回 描述
ActiveCell Range  
ActiveChart Chart  
ActivePrinter String  
ActiveSheet Sheet  
ActiveWindow Window  
ActiveWorkbook Workbook  
Selection Range/Chart/Control 取决于用户的选择
ThisCell Range 调用一个用户定义的函数单元格
ThisWorkbook Workbook  
Caller Range 返回使用此函数的单元格

5.5 常用的简化文件操作

5.5.1从用户那里获得文件名

代码清单5.5:从用户那里获取单个工作薄

'代码清单5.5: 从用户那里获取单个工作薄
Sub TestGetFile()
Dim nIndex As Integer
Dim sFile As String 'Get a batch of Excel files
sFile = GetExcelFile("Testing GetExcelFile Function") 'make sure dialog wasn't cancelled - in which case
'sFile would equal False
If sFile = "False" Then
Debug.Print "No file selected."
Exit Sub
End If 'OK - we have a valid file
Debug.Print sFile End Sub 'Presents user with a GetOpenFileName dialog which allows
'single file selection.
'return a single of filename
Function GetExcelFile(sTitle As String) As String Dim sFilter As String
Dim bMultiSelect As Boolean sFilter = "Workbooks (*.xls),*.xls"
bMultiSelect = False GetExcelFile = Application.GetOpenFilename _
(FileFilter:=sFilter, Title:=sTitle, MultiSelect:=bMultiSelect) End Function

代码清单5.6:从用户那里获取一批工作薄

'代码清单5.6: 从用户那里获取一批工作薄
Sub TestGetFiles()
Dim nIndex As Integer
Dim vFiles As Variant 'Get a batch of Excel files
vFiles = GetExcelFiles("Testing GetExcelFiles Function") 'make sure dialog wasn't cancelled - in which case
'vFiles would equal False
If Not IsArray(vFiles) Then
Debug.Print "No files selected."
Exit Sub
End If 'OK - loop through the fileNames
For nIndex = To UBound(vFiles)
Debug.Print vFiles(nIndex)
Next nIndex End Sub 'Presents user with a GetOpenFileName dialog that allows
'Multiple file selection.
'Returns an array of filenames.
Function GetExcelFiles(sTitle As String) As Variant
Dim sFilter As String
Dim bMultiSelect As Boolean sFilter = "Workbooks (*.xls), *.xls "
bMultiSelect = True GetExcelFiles = Application.GetOpenFilename _
(filefilter:=sFilter, Title:=sTitle, MultiSelect:=bMultiSelect) End Function

默认情况下,VBA数组是基于0的。但是,GetOpenFilename多选模式返回的数组是基于1的。

5.5.2 使用GetSaveAsFilename选取合适的位置

代码清单5.7:GetSaveAsFilename的基本使用

'代码清单5.7: GetSaveAsFilename 的基本使用
Sub SimpleGetSaveAsFilename()
Dim sFile As String
Dim lResponse As Long
Dim sMsg As String Do
sFile = Application.GetSaveAsFilename
sMsg = "you chose: " & sFile & " . Keep experimenting?"
lResponse = MsgBox(sMsg, vbYesNo) Loop While lResponse = vbYes End Sub

5.5.2.1 分解文件名

代码清单5.8:分解文件名为路径和文件名

'代码清单5.8: 分解文件名为路径和文件名
'A simple procedure for testing the
'BreakDownName procedure
Sub TestBreakdownName()
Dim sPath As String
Dim sName As String Dim sFileName As String
Dim sMsg As String sFileName = Application.GetSaveAsFilename
BreakdownName sFileName, sName, sPath
sMsg = "the file name is: " & sName & vbCrLf
sMsg = sMsg & "the path is: " & sPath & vbCrLf MsgBox sMsg, vbOKOnly End Sub Function GetShortName(sLongName As String) As String
Dim sPath As String
Dim sShortName As String BreakdownName sLongName, sShortName, sPath
GetShortName = sShortName End Function '当有2个返回值时,用byRef参数过程
Sub BreakdownName(sFullName As String, ByRef sName As String, ByRef sPath As String)
Dim nPos As Integer 'Find out where the filename begins
nPos = FileNamePosition(sFullName)
If nPos > Then
sName = Right(sFullName, Len(sFullName) - nPos)
sPath = Left(sFullName, nPos - )
Else
'invalid sFullName - don't change anything
End If End Sub 'Returns the position or index of the first
'character of the filename given a full name
'A full name consists of a path and a filename
'Ex. FileNamePosition("c: \Testing\Test.txt") = 11
Function FileNamePosition(sFullName As String) As Integer
Dim bFound As Boolean
Dim nPosition As Integer bFound = False
nPosition = Len(sFullName) Do While bFound = False
If nPosition = Then Exit Do If Mid(sFullName, nPosition, ) = "\" Then
bFound = True
Else
nPosition = nPosition -
End If
Loop If bFound = False Then
FileNamePosition =
Else
FileNamePosition = nPosition
End If End Function

5.6 检查操作环境

代码清单5.9:使用Application对象属性获取有效的系统信息

'代码清单5.9:使用Application 对象属性获取有效的系统信息
Sub InspectTheEnvironment()
Debug.Print Application.CalculationVersion
' Debug.Print Application.MemoryFree
' Debug.Print Application.MemoryUsed
Debug.Print Application.OperatingSystem
Debug.Print Application.OrganizationName
Debug.Print Application.UserName
Debug.Print Application.Version End Sub

5.7有用的两个额外成员

第一个是CutCopyMode属性,这个属性决定当剪切或复制时,是否在选中区域边界周围显示移动的破折号。

Application.CutCopyMode = False

第二个功能是InputBox方法:

'5.7 InputBox 函数用法的例子
Sub SimpleInputBox()
Dim vInput As Variant
vInput = InputBox("What is your name?", "introduction", Application.UserName)
MsgBox "Hello, " & vInput & ". Nice to meet you.", vbOKOnly, "Introduction" End Sub

5 Application 对象的更多相关文章

  1. Application对象、ViewState对象、分页展示--2017年1月4日

    Application对象 存储 Application 变量  Application["application名称"] = "application的值"; ...

  2. JSP内置对象之application对象

    虽然常把Web应用称为B/S架构的应用,但其实Web应用一样是C/S结构的应用,只是这种应用的服务器是Web服务器,而客户端是浏览器. 现在抛开Web应用直接看Web服务器和浏览器. Web服务器负责 ...

  3. 什么是Cookie对象,Session对象,Application对象。

    Cookie是: 一个由网页服务器放在您硬盘上的非常小的文本文件. 它本质上就像您的身份证明一样,并且不能像代码那样被执行或被用来散布病毒.它只能被您使用并且只能由提供的服务器读取. 使用Cookie ...

  4. Application对象、Session对象、Cookie对象、Server对象初步认识

    Application对象:记录应用程序参数的对象 用于共享应用程序级信息,即多个用户共享一个Application对象.在第一个用户请求ASP.NET文件时,将启动应用程序并创建Applicatio ...

  5. Android Application 对象介绍

    What is Application Application和Actovotu,Service一样是android框架的一个系统组件,当android程序启动时系统会创建一个 application ...

  6. ASP.NET中application对象的用法

    一.Application对象的理解 Application对象在实际网络开发中的用途就是记录整个网络的信息,如上线人数.在线名单.意见调查和网上选举等.在给定的应用程序的多有用户之间共享信息,并在服 ...

  7. [原创]java WEB学习笔记47:Servlet 监听器简介, ServletContext(Application 对象), HttpSession (Session 对象), HttpServletRequest (request 对象) 监听器,利用listener理解 三个对象的生命周期

    本博客为原创:综合 尚硅谷(http://www.atguigu.com)的系统教程(深表感谢)和 网络上的现有资源(博客,文档,图书等),资源的出处我会标明 本博客的目的:①总结自己的学习过程,相当 ...

  8. ASP.NET中application对象

    ASP.NET中application对象的使用. Application对象的应用  1.使用Application对象保存信息  (1).使用Application对象保存信息  Applicat ...

  9. 初识 Asp.Net内置对象之Application对象

    Application对象 Applocation对象用于共享应用程序级信息,即多个用户可以共享一个Applocation对象. 用户在请求Asp.Net文件时,将启动应用程序并且创建Applicat ...

  10. jsp 用application对象制作留言板

    <%@ page contentType="text/html; charset=gb2312"%> <html> <body> <for ...

随机推荐

  1. stl sort和qsort的使用

    好不容易使用了下stl的qsort函数,顺便和sort函数一起总结下: 很多时候我们都需要用到排序. 例如: 1 #include <iostream> #include <algo ...

  2. Python之条件判断

    Python之条件判断 计算机之所以能做很多自动化的任务,因为它可以自己做条件判断. 比如,输入用户年龄,根据年龄打印不同的内容,在Python程序中,用if语句实现: age = 20 if age ...

  3. 83-MACD 移动平均汇总/分离指标.(2015.7.3)

    MACD 移动平均汇总/分离指标 ~计算: · EMA(12,t)=EMA(12,t-1) * 11/13 + Close * 2/13 · EMA(26,t)=EMA(26,t-1) * 25/27 ...

  4. Linux 搭建 squid 代理服务器 三种模式

    CentOS 6.7 squid 代理服务器 一般有两张或以上网卡,一张链接公网,访问外网资源,一张位于局域网. 代理服务器可以提供文件缓存.复制和地址过滤等服务,充分利用有限的出口带宽,加快内部主机 ...

  5. JS 比较运算符 逻辑运算符

    逻辑运算符 三元运算符 摘自:http://www.w3school.com.cn/js/js_comparisons.asp

  6. UART整理

    通用异步收发器简称UART,英文全称"Universal Asynchronous Receiver Transmitter".UART使用标准的TTL/CMOS逻辑电平(0~5V ...

  7. HttpModule用户的验证

    HttpModule是向实现类提供模块初始化和处置事件.当一个HTTP请求到达HttpModule时,整个ASP.NET Framework系统还并没有对这个HTTP请求做任何处理,也就是说此时对于H ...

  8. C51 中断 个人笔记

    总架构图 IE寄存器 控制各个中断源的屏蔽与允许 TCON寄存器 各个中断源的请求标志位&有效信号的规定 中断源及其优先级 中断号写程序的时候要用 CPU处理中断三原则 1.CPU同时接收到几 ...

  9. openjudge6252 带通配符的字符串匹配

    描述 通配符是一类键盘字符,当我们不知道真正字符或者不想键入完整名字时,常常使用通配符代替一个或多个真正字符.通配符有问号(?)和星号(*)等,其中,“?”可以代替一个字符,而“*”可以代替零个或多个 ...

  10. Test for Job 图上的动态规划(DAG)

    Test for Job Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 11399   Accepted: 2697 Des ...