CreateObject 函数示例
该示例使用 CreateObject 函数设置一个对 Microsoft Excel 的引用 (xlApp)。它使用该引用来访问 Microsoft Excel 的 Visible 属性,并使用 Microsoft Excel 的 Quit 方法将其关闭,最后再释放该引用。 Dim xlApp As Object '定义存放引用对象的变量。
Set xlApp = CreateObject(\ '如果要让该应用程序可见,
则需将 Visible 属性设为 True。 xlApp.Visible = True
'可以使用 xlApp 访问 Microsoft Excel 的 '其它对象。
xlApp.Quit '完成时,调用 Quit 方法关闭
Set xlApp = Nothing '该应用程序,然后释放该引用。
CurDir 函数
返回一个 Variant (String),用来代表当前的路径。 语法
CurDir[(drive)]
可选的 drive 参数是一个字符串表达式,它指定一个存在的驱动器。如果没有指定驱动器,或 drive 是零长度字符串 (\,则 CurDir 会返回当前驱动器的路径。
CurDir 函数示例
本示例使用 CurDir 函数来返回当前的路径。
' 假设 C 驱动器的当前路径为“C:\\WINDOWS\\SYSTEM”。 ' 假设 D 驱动器的当前路径为“D:\\EXCEL”。 ' 假设 C 为当前的驱动器。 Dim MyPath
MyPath = CurDir ' 返回“C:\\WINDOWS\\SYSTEM”。
MyPath = CurDir(\返回“C:\\WINDOWS\\SYSTEM”。 MyPath = CurDir(\返回“D:\\EXCEL”。
CVErr 函数
返回 Error 子类型的 Variant,其中包含指定的错误号。 语法
CVErr(errornumber)
必要的 errornumber 参数可以是任何有效的错误号代码。 说明
可以在过程中,使用 CVErr 函数来创建用户自定义错误。例如,如果创建一个函数,它可以接受若干个参数,且正常返回一个字符串,则可以让函数来判断输入的参数,确认它们是在可接受的范围内。如果不是的话,此函数将不会返回所要的字符串。在这种情况下,CVErr 可以返回一个错误号,并告知应该采取的行动。
注意,Error 的隐式转换是不允许的,例如,不能直接把 CVErr 的返回值赋值给一个非 Variant 的变量。然而,可以对 CVErr 的返回值进行显式转换(使用 CInt、CDbl 等等),并赋值给适当的数据类型变量。
CVErr 函数示例
本示例使用 CVErr 函数返回一 Variant 类型的值,其 VarType 为 vbError (10)。如果传进去的参数不是一个数字,用户自定义函数
CalculateDouble 将会返回错误信息。可用 CVErr 返回来自用户自定义过程的自定义错误,或改变处理运行时错误的方式。IsError 函数可用来测试返回值是否代表错误状态。
' 调用 CalculateDouble,且传入一会产生错误的参数。 Sub Test()
Debug.Print CalculateDouble(\End Sub
' 定义 CalculateDouble 函数过程。 Function CalculateDouble(Number) If IsNumeric(Number) Then
CalculateDouble = Number * 2 ' 返回结果。 Else
CalculateDouble = CVErr(2001) ' 返回一自定义错误码。 End If End Function
Date 函数
返回包含系统日期的 Variant (Date)。 语法 Date 说明
为了设置系统日期,请使用 Date 语句。
Date 函数示例
本示例使用 Date 函数返回系统当前的日期。 Dim MyDate
MyDate = Date ' MyDate 的值为系统当前的日期。
DateAdd 函数
返回包含一个日期的 Variant (Date),这一日期还加上了一段时间间隔。 语法
DateAdd(interval, number, date) DateAdd 函数语法中有下列命名参数: 部分 描述 interval 必要。字符串表达式,是所要加上去的时间间隔。 number date 设置
必要。数值表达式,是要加上的时间间隔的数目。其数值可以为正数(得到未来的日期),也可以为负数(得到过去的日期)。 必要。Variant (Date) 或表示日期的文字,这一日期还加上了时间间隔。 interval 参数具有以下设定值:
设置 描述 yyyy 年 q m y d w ww h n s 说明
可以使用 DateAdd 函数对日期加上或减去指定的时间间隔。例如,可以用 DateAdd 来计算距今天为三十天的日期;或者计算距现在为 45 分钟的时间。 为了对 date 加上“日”,可以使用“一年的日数” (“y”),“日” (”d”) 或“一周的日数” (”w”)。
DateAdd 函数将不返回有效日期。在以下实例中将 1 月31 日加上一个月: DateAdd(m, 1, 31-Jan-95)
上例中,DateAdd 返回 1995 年 2 月 28 日,而不是 1995 年 2 月 31 日。如果 date 是 1996 年 1 月 31 日,则由于 1996 年是闰年,返回值是 1996 年 2 月 29 日。
如果计算的日期超前 100 年(减去的年度超过 date 中的年份),就会导致错误发生。
如果 number 不是一个 Long 值,则在计算时取最接近的整数值来计算。 注意 DateAdd 返回值的格式由 Control Panel设置决定,而不是由传递到date 参数的格式决定。
季 月 一年的日数 日 一周的日数 周 时 分钟 秒 DateAdd 函数示例
本示例先取得一个日期,再用 DateAdd 函数显示未来数月后的日期。 Dim FirstDate As Date ' 声明变量。 Dim IntervalType As String Dim Number As Integer Dim Msg
IntervalType = \指定以“月份”作为间隔。 FirstDate = InputBox(\
Number = InputBox(\
Msg = \MsgBox Msg
DateDiff 函数
返回 Variant (Long) 的值,表示两个指定日期间的时间间隔数目。 语法
DateDiff(interval, date1, date2[, firstdayofweek[, firstweekofyear]]) DateDiff 函数语法中有下列命名参数: 部分 描述 必要。字符串表达式,表示用来计算date1 和 date2 的时间差的时间间隔 必要;Variant (Date)。计算中要用到的两个日期。 可选。指定一个星期的第一天的常数。如果未予指定,则以星期日为第一天。 1 月 1 日的星期为第一周。 设置
interval Date1□date2 Firstdayofweek firstweekofyear 可选。指定一年的第一周的常数。如果未予指定,则以包含 interval 参数的设定值如下: 设置 描述