1、VB For循环
基本语法
For counter [ As datatype ] = start To end [ Step step ]
[ statements ]
[ Continue For ]
[ statements ]
[ Exit For ]
[ statements ]
Next [ counter ]
举个例子 为打印1-5
for i = 1 To 5
Print(i)
Next
' res: 1 2 3 4 5
反过来打印
For i = 5 To 1 Step -1
Print(i)
Next
' res: 5 4 3 2 1
强制退出For循环,请使用Exit For, 相当于c++中的break,对于多重循环,只能退出离它最近的循环,若要跳出最外层循环,需要用到GoTo
2、VB IF选择
基本语法
' Multiline syntax:
If condition [ Then ]
[ statements ]
[ ElseIf elseifcondition [ Then ]
[ elseifstatements ] ]
[ Else
[ elsestatements ] ]
End If
' Single-line syntax:
If condition Then [ statements ] [ Else [ elsestatements ] ]
举个例子 闰年判断
Dim y As Long
y = Year(Now)
If y Mod 400 = 0 Then
MsgBox Str(y) & "是闰年"
ElseIf y Mod 4 = 0 And y Mod 100 <> 0 Then
MsgBox Str(y) & "是闰年"
Else
MsgBox (Str(y)) & "是平年"
End If
3、函数
基本语法
[Private][Public][Static]Function <函数过程名>([形参列表])[As <类型>]
<语句系列>
[<函数名> = <表达式>]
[Exit Function]
[<语句系列>]
[<函数名> = <表达式>]
End Function
函数的参数传递分为两种
举个例子:判断一个数是否是素数
Function isPrime(ByVal num As Long) As Boolean
Dim tmp As Double
isPrime = True
If num = 1 Then
isPrime = False
Else
tmp = Sqr(num)
For i = 2 To tmp
If num Mod i = 0 Then
isPrime = False
Exit For
End If
Next
End If
End Function
4、日期
详细可见博客1,博客2
程序中使用到的
Dim dt As Date, dateStr As String, datas As String
dates = "2019-04-08"
dateStr = Format(dt, "yyyy-mm-dd hh.mm.ss") '将时间类型指定格式的字符串
week = Weekday(CDate(dates)) '将字符串转为Date类型,再获取星期几
5、字符串
详细见博客
mid(字符串, idx,len) ByRef 从字符串idx处,取出长度为len的子串
trim(str) ByVal去掉字符串前后的空格
len(str) ByVal 返回字符串的长度
Join(list[, delimiter]) As String 返回一个字符串,该字符串是通过连接某个数组中的多个子字符串而创建的。list 必需的。包含被连接子字符串的一维数组。delimiter 可选的。在返回字符串中用于分隔子字符串的字符。如果忽略该项,则使用空格(" ")来分隔子字符串。如果delimiter是零长度字符串(""),则列表中的所有项目都连接在一起,中间没有分隔符。
Split(str[, delimiter]) 返回的是一个字符串数组 ,默认分隔符为" "
Dim timeStr As String, timeArr() As String, h As String, m As String, s as String
timeStr = "12:23:34"
'获取时,分,秒
'1、用字符串分隔的方法
timeArr = Split(timeStr, ":")
h = Val(timeArr(0))
m = Val(timeArr(1))
s = Val(timeArr(2))
'2、用mid来截取字符串
h = Val(Mid(timeStr(i), 1, 2)) '获取小时
m = Val(Mid(timeStr(i), 4, 2)) '获取分钟
s = Val(Mid(timeStr(i), 7, 2)) '获取秒
6、数组
VB中的数组可以自已声明下标的起始位置,当数组没有声明成定长的,可以通过redim来调整数组长度,使用preserve保留现有的数据,因为数组的长度可能不从0开始,所以数组只能通过以下方式获取
length = UBound(arr) - LBound(arr) + 1
7、Collection
Collection可以为每一个元素设置一个key,通过key对数组进行访问,这相当于c++中的map
项目中利用Collection建立学生与其导师的对应关系,每一位学生的导师唯一,但每一位导师可能需要指导多位学生,就是一对多的关系,Collection中存储的是Array
代码如下:
'根据学生与老师的关系生成map
For i = 2 To relaRows
If relation(i, 1) <> "" And relation(i, 5) <> "" Then
Dim tea As String, stu As String
tea = relation(i, 5)
stu = relation(i, 1)
stuCol.Add tea, stu
If exists(teaCol, tea) = False Then
Dim arr() As String
ReDim arr(0)
arr(0) = stu
teaCol.Add arr, tea
Else
'若已在teaCol中存在,则先删除Item,再添加
arr = teaCol.Item(tea)
ReDim Preserve arr(UBound(arr) + 1)
arr(UBound(arr)) = stu
teaCol.Remove (tea)
teaCol.Add arr, tea
End If
Else
myNum = myNum + 1
End If
Next
如果直接访问集合中不存在的元素,VB会直接报错,所以在使用元素之前,需判断集合中的元素是否存在。
'判断元素是否在集合
'Collection中的元素为数组
Function exists(pCol As Collection, pKey As String) As Boolean
On Error Resume Next
exists = (UBound(pCol(pKey)) >= 0)
End Function
'Collection中的元素为字符串
Function exists1(pCol As Collection, pKey As String) As Boolean
On Error Resume Next
exists1 = Len(pCol(pKey) >= 0)
End Function
下次再补充吧