我有这个代码:
' Option Explicit
Public Function Clean(Text)
On Error Resume Next
' Dim Chars As ?????????
Chars = Array("\", "/", ":", "*", "?", """", "<", ">", "|")
For Each Replaced In Chars
Text = Replace(Text, Replaced, "")
Next
Clean = CStr(Text)
End Function
Run Code Online (Sandbox Code Playgroud)
但是我在使用时遇到错误,Option Explicit因为没有声明Chars,但是我必须使用什么类型来调暗数组(Dim Chars As ???????)?
更正版本:
Option Explicit
Public Function Clean(ByVal Text As String)
Dim Chars As Variant
Dim Replaced As Variant
Chars = Array("\", "/", ":", "*", "?", """", "<", ">", "|")
For Each Replaced In Chars
Text = Replace(Text, Replaced, "")
Next
Clean = Text
End Function
Run Code Online (Sandbox Code Playgroud)
通常表现更好的版本:
Option Explicit
Public Function Clean(ByVal Text As String)
Dim Chars As Variant
Dim RepIndex As Long
Chars = Array("\", "/", ":", "*", "?", """", "<", ">", "|")
For RepIndex = 0 To UBound(Chars)
Text = Replace$(Text, Chars(RepIndex), "")
Next
Clean = Text
End Function
Run Code Online (Sandbox Code Playgroud)
理解变体很重要,应该特别注意使用Variant版本的字符串函数而不是带有"$"类型装饰后缀的String类型.
大多数情况下,由于性能成本,您可能希望尽可能避免使用Variants.
这个版本可能表现得更好:
Option Explicit
Public Function Clean(ByVal Text As String)
Const Chars As String = "\/:*?""<>|"
Dim RepIndex As Long
For RepIndex = 1 To Len(Chars)
Text = Replace$(Text, Mid$(Chars, RepIndex, 1), "")
Next
Clean = Text
End Function
Run Code Online (Sandbox Code Playgroud)
VB6中没有"Char"类型,变量声明也没有任何初始化语法.