加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 大数据 > 正文

VB十七种可用一行代码完成的技巧

发布时间:2020-12-16 23:26:21 所属栏目:大数据 来源:网络整理
导读:编程要讲效率,尽管现在的计算机,速度是不成问题, 但是,如果一行代码能完成,为什么要用更多的代码呢? 现在介绍VB中一些可用一行代码完成的技巧。1、下列代码,则是对逻辑运算不清楚造成If A=true ThenC= Not BElseC= BEnd If 可以:C=A XOR B2、如果加
      编程要讲效率,尽管现在的计算机,速度是不成问题,
但是,如果一行代码能完成,为什么要用更多的代码呢?
      现在介绍VB中一些可用一行代码完成的技巧。

1、下列代码,则是对逻辑运算不清楚造成
If A=true Then
C= Not B
Else
C= B
End If

 可以:
C=A XOR B


2、如果加上下列代码:
If C=true then
D=28
Else
D=29 
End IF

D=Iif((A XOR B),28,29)


3、布尔赋值,常被人忽略,如:
If A= 13 then

B=True

Else

B=False 

End If

 可以:
B = A = 13

 或者:
B = (A = 13)

 我更喜欢用后者,这样代码易于看懂。

4、字串有效性检测:
If IsNull(StrOrg) Or StrOrg="" then

 可以:
If Len(StrOrg & "")<>0 then


5、字串重复次数
RepeatCount=Ubound(Split(StrOrg,StrFind))

 同样,如果要对字串有效性判断:
RepeatCount=Iif((Len(StrOrg & "")=0),Ubound(Split(StrOrg,StrFind))


6、有时需要判断字串数组中是否有这一元素,这时最好不用数组,而用分隔符字串,于是: 
If Len(OrgStr)= Len(Replace(OrgStr,FindStr)) then

 则表明,此元素不存在。 


7、对数组初始化,最好用变体,这样,也是一行语句,如:
IntArr=Array(12,29,30,31,52,24,60)

 注意,此时需要用变量后缀。上面代码,如要定义为长整型,则
IntArr=Array(12&,28&,29&,30&,31&,52&,24&,60&)

 要将IntArr 定义为变体


8、判断大小:
IntMax = Iif((IntA > IntB),IntA,IntB) 

IntMin = Iif((IntA < IntB),IntB)

9、按索引的Select Case
Function GetChoice(Ind As Integer)
GetChoice = Choose(Ind,"Speedy","United","Federal")
End Function


10、按表达式的Select Case(这种转换要求不能有Case Else的才可以这样,否则会出错)
Function MatchUp (CityName As String)
Matchup =tch(CityName = "London","English",CityName _
= "Rome","Italian",CityName = "Paris","French")
End Function


11、使用Iif,前面已有 
Function CheckIt (TestMe As Integer)
CheckIt = IIf(TestMe > 1000,"Large","Small")
End Function


12、字串动态数组是否已初始化
If Len(Join(StrArr))=0 then

 字串动态数组未初始化。


13、指定只读CombBox的当前值,如果能确认这个值就在其中,一定不会错,则:
Combbox=CurValue

 注意,不可以写成:
Combbox.text=CurValue

 前者实际是写 _default 这个属性,而后者则是写Text 因为只读,则会导致错误
14、如果有下列代码:
Select Case CombBox.text
Case "London"
Call FuncStrLang(3)
Case "Rome"
Call FuncStrLang(5)
......
End Select

 则可以用ItemData属性,即:
"London" 的 Itemdata=3
"Rome" 的 Itemdata=5

 于是:
Call FuncStrLang(CombBox.ItenData)


15、如果有下列代码: 
Select Case CombBox.text
Case "London"
Call ClsCity.CityIntr_London
Case "Rome"
Call ClsCity.CityIntr_Rome
......
End Select

 只要:
CallByName ClsCity,"CityIntr_" & CombBox.text,vbMethod


16、复制数组到另一变量中:
Dim iOrgArr(30) as Integer 
Dim iDesArr as Variant
......
iDesArr = iOrgArr

 即主变体直接取数组指针,则所有元素都复制了过去。


17、如果有下列代码:
Do While Not RsAdo.Eof
If len(DesStr)<>0 then
DesStr=DesStr & VbTab
End if
DesStr=RsAdo!Rec_id 
RsAdo.MoveNext
loop

 则只要:
DesStr=RsAdo.GetString()

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读