我有以下代码返回wmi信息(未知数组)
For Each objMgmt In oquery.Get()
For Each theproperty In objMgmt.Properties
If (TypeOf objMgmt(theproperty.Name) Is System.Array) Then
myrow(theproperty.Name) = ConvertArray(CType(objMgmt(theproperty.Name), Array)).Trim
end if
next
next
函数ConvertArray将其转换为字符串值。
Function ConvertArray(ByVal myarray As System.Array) As String
Dim tel As Integer
Dim res As String = ""
If myarray.Length = 0 Then
Return ""
End If
If myarray.Length = 1 Then
res = myarray(0).ToString
Else
For tel = 0 To myarray.Length - 1
If TypeOf myarray(tel) Is UInt16 Then
res = res + "[" + CType(myarray(tel), UInt16).ToString + "] , "
Else
res = res + CStr(myarray(tel)) + " , "
End If
Next
res = Mid(res, 1, Len(res) - 2)
End If
Return res
End Function
“myarray(tel)”在我明确打开选项时给出“Option Strict On禁止后期绑定”问题。 如何解决这个问题,wmi会根据查询返回整数或字符串。
答案 0 :(得分:7)
您可以myarray.GetValue(0)
代替myArray(0)
。即使使用Option Strict On,这也可以使用。