Loading AI tools
来自维基百科,自由的百科全书
Visual Basic for Applications(VBA)是Visual Basic的一种巨集语言,主要能用来扩展Windows的应用程式功能,特别是Microsoft Office软体。也可说是一种应用程式视觉化的Basic Script。 1994年发行的Excel 5.0版本中,即具备了VBA的巨集功能。
编程范型 | Multi-paradigm编程语言 |
---|---|
实作者 | Microsoft |
发行时间 | 1993年 |
当前版本 | 7.1(Microsoft Office 2021) |
型态系统 | 静态/动态混合,强/弱混合 |
操作系统 | Microsoft Windows, Mac OS X |
许可证 | 专有EULA |
网站 | learn |
启发语言 | |
QuickBASIC, Visual Basic |
即Primary Type Data,下述列表的括号内为字节数:
相当于C语言的struct,例如:
Type 自定义类型名 元素名 As 类型 … [元素名 As 类型] End Type
Option Base 0 '數組索引值從0開始
Option Base 1 '數組索引值從1開始
Dim MyArray(10) '聲明一個數組變量,10是最大的可用的數組索引值
MyArray(5) = 101 '給數組的元素賦值
Dim Data(10,5) '聲明一個二維數組變量
Data(1,1) = "A001" '給數組元素賦值
Dim cArr(-11 To 20, 1 To 3) As String '聲明一個數組,定義數組索引值的上下界
Dim dArr() As String '聲明動態數組
ReDim dArr(0 To 5, 1 To 2) '改變動態數組的尺寸默認把原數據清除。如果保留原來的數據,必須加上參數Preserve。
'使用Preserve參數時只能改變最後一維的大小
If UBound(vTemp) = -1 Then
'判斷數組變量vTemp是否為 空數組
End If
Erase MyArrar, Data 'Erase語句清除數組元素,釋放變量佔用的空間
日期常量由符号“#”将字符括起来,如#2012-1-1#。
系统定义常量有3个:True、False和Null。
固有常量是编程时引用的对象库定义的常量。所有固有常量都可以在宏或VBA代码中使用。通常,固有常量通过前两个字母来指明定义该常量。来自VB库的常量则以“vb”开头。来自Access的常量以“ac”开头。可以使用对象浏览器来查看所有对象库中的固有常量列表。
可以自行定义常量。如:
Global Const 符号常量名称 = 常量值
例如:
Private Declare Function getFrequency Lib "kernel32" _ Alias "QueryPerformanceFrequency" (cyFrequency As Currency) As Long Private Declare Function getTickCount Lib "kernel32" _ Alias "QueryPerformanceCounter" (cyTickCount As Currency) As Long
if 條件1 then 語句1 elseif 條件2 then 語句2 elseif ... ... else 語句n end if
Select Case 表達式 Case 表達式列表1 語句1 Case 表達式列表2 語句2 ... Case 表達式列表n 語句n End Select
其中的表达式列表可以为:
Do While或Until 條件 語句塊1 Exit Do 語句塊2 Loop
Do 語句塊1 Exit Do 語句塊2 Loop While或Until 條件
For 循環控制變量=初值To 終值Step 步長 語句塊 ‘Exit For語句可以跳出循環體 Next
For Each 循環控制變量 In 集合變量 語句塊 Exit For語句可以跳出循環體 Next 循環控制變量
VBA没有类似C语言的continue语句。通常可如此写程序:
For 循環控制變量=初值 To 終值 Step 步長
Do '用于模拟continue
語句塊
If 条件 Then Exit Do '用于模拟continue
語句塊
Loop While False '用于模拟continue
Next
With 對象引用 語句塊 End With
On Error Goto 出錯處理語句的label '跳轉到出錯處理語句
或
On Error Resume Next '遇到錯誤,不管錯誤,繼續往下執行
使用REM或者单引号开始的行。
如果一行包括多条语句,用冒号分割各个语句。跨多行的语句,在行末用“空格加下划线”表示续行。
Sub 過程名(參數表) 語句塊 Exit Sub 語句塊 End Sub
Function 函數名(參數表) As Type 語句塊 函數名=表達式 Exit Function End Function
可以是Private、Public、Friend、Static等修饰。
调用函数/过程时,可以加括号或者不加括号。如果调用表达式作为一行的一部分,那么必须用参数,例如函数调用的返回值赋给变量。 调用过程时, 可以使用/不使用call关键字。使用call语句调用过程,如果无参数,则不加括号;如果有参数,必须加括号。如果调用时用括号包住单个参数,则该参数强行按值传递。需要特别注意,不用call不加括号的调用,形参与实参是传值(passed by value)而不是传引用(passed by reference),这会导致一些对象的方法调用失败。例如:
Dim cn As ADODB.Connection
Set cn = CurrentProject.Connection
Dim rs As New ADODB.Recordset
rs.Open "SELECT * FROM myTable" , cn
Dim ExcelApp As New Excel.Application
Dim ExcelWst As Worksheet
Set ExcelWst = ExcelApp.Workbooks.Add.Worksheets(1)
ExcelWst.Range("A2").CopyFromRecordset(rs) '失败,无法执行该行
ExcelWst.Range("A2").CopyFromRecordset rs '可成功执行该行
VBA的常用内置函数列表参见:[1] (页面存档备份,存于互联网档案馆)
比较特殊的运算符有指数运算^,浮点除法/,整数除法\,取模运算Mod,不等逻辑比较运算<>
Seamless Wikipedia browsing. On steroids.
Every time you click a link to Wikipedia, Wiktionary or Wikiquote in your browser's search results, it will show the modern Wikiwand interface.
Wikiwand extension is a five stars, simple, with minimum permission required to keep your browsing private, safe and transparent.