как я выражаю термин, если x является целым числом на языке VBA? Я хочу написать код, который делает что-то, если x является целым числом и делает что-то еще, если не с vba выделяются.
Sub dim()
Dim x is Variant
'if x is integer Then
'Else:
End Sub
If IsNumeric(x) Then 'it will check if x is a number
Если вы хотите проверить тип, вы можете использовать
If TypeName(x) = "Integer" Then
Зависит от того, что вы имеете в виду - тип данных "Целое" или "Целое" в смысле этого слова: "Число без десятичной дроби". Если вы имеете в виду последний, то достаточно быстрой ручной проверки (см. первый пример); если вы имеете в виду первый, то есть три способа посмотреть на типы данных, все с разными "за" и "против":
Public Sub ExampleManual()
Dim d As Double
d = 1
If Fix(d) = d Then
MsgBox "Integer"
End If
End Sub
Public Sub ExampleTypeName()
Dim x As Integer
MsgBox TypeName(x)
End Sub
Public Sub ExampleTypeOf()
Dim x As Excel.Range
Set x = Selection
''//Using TypeOf on Objects set to Nothing will throw an error.
If Not x Is Nothing Then
If TypeOf x Is Excel.Range Then
MsgBox "Range"
End If
End If
End Sub
Public Sub ExampleVarType()
Dim x As Variant
''//These are all different types:
x = "1"
x = 1
x = 1&
x = 1#
Select Case VarType(x)
Case vbEmpty
Case vbNull
Case vbInteger
Case vbLong
Case vbSingle
Case vbDouble
Case vbCurrency
Case vbDate
Case vbString
Case vbObject
Case vbError
Case vbBoolean
Case vbVariant
Case vbDataObject
Case vbDecimal
Case vbByte
Case vbUserDefinedType
Case vbArray
Case Else
End Select
End Sub