プロが教える店舗&オフィスのセキュリティ対策術

Sub Macro2()
Dim mystr As String

mystr = "1"
If IsDate(mystr) = False Then
MsgBox "NO"
End If

End Sub

これなら日付型かどうかを取得できるのに、

Sub Macro1()
Dim mystr As String

mystr = "1"
If IsNumber(mystr) = False Then
MsgBox "NO"
End If

End Sub
だと、IsNumberがコンパイルエラーになります。

変数に入っている値が数値として評価できるかを取得する方法を教えてください。

A 回答 (3件)

こんにちは。



これは初歩的なことではあっても、最初はなかなか手こずります。こういうことは、教えもらったほうが早いようです。

#2さんのおっしゃる通り、IsNumberは、ワークシート関数ですから、VBA上での使い方はお分かりになるとは思いますが、しかし、私は、VBAでは、IsNumber は使いません。

ただし、Cells のText プロパティでも同じ反応ですが、String型のデフォルト値は、""(長さ0の文字列)です。基本的には、String型で値を取ることはしません。それに、ふつうは、Cellsから直接取り出すことは避けたほがいいです。一端、変数に入れてから、判定させたほうがよいです。ワークシートの数式は、関数に関数を重ねますが、VBAなどの言語では、あまり関数や数式をネストしないほうがよいと言われます。

IsNumeric VBA関数は、少し意味合いが違います。「[数字]かどうか」という判定で、「[数値]かどうか」ではありません。もちろん、以下のようなワークシート関数を応用したコードはあるとは思いますが、これだと、他のVBAやVBでは応用できません。(英語で考えると変ですね。数値というのは、"Numeric"です。数字は、"Figure" です。もしかしたら、名前付けの時に間違えたかもしれません。(^^;)

'//
Sub Macro3()
Dim myVal As Variant
Dim myVal2 As Double
 myVal = "1"
 If WorksheetFunction.IsNumber(myVal) Then
   MsgBox myVal2
 Else
  MsgBox "Not Numeric: " & myVal
 End If
End Sub

'VBA関数を使う場合は、上記とはマクロとしての目的が違いますが、このようにします。
'あえて、Double型にしましたが、不要な場合はLong型にしてもよいです。

Sub Macro4()
Dim myVal As Variant
Dim myVal2 As Double
 myVal = "1"
 If IsNumeric(myVal) Then
  myVal2 = CDbl(myVal) '直接入れるわけにはいかないし、Val関数を使うと丸められてしまう。
  MsgBox myVal2
 Else
  MsgBox "Not Numeric: " & myVal
 End If
End Sub

'//
'なお、Macro3,4 の Dim mystr As String は myVal As Variant にしました。
'String型なのに、他のものを入れても同じことですから。
    • good
    • 1
この回答へのお礼

ありがとうございます。

お礼日時:2014/07/23 19:27

紛らわしいですが、数値かどうか評価する関数は


IsNumber:ワークシートで使う関数と、
IsNumeric:マクロ(VBA)で使う関数の2つあります。
この2つは使うところだけでなく入力に対する挙動にも違いがあり、
またセルの .value か .text を対象にするかでも違いがあります。
http://ameblo.jp/sukiti/entry-11325623598.html
    • good
    • 1
この回答へのお礼

ありがとうございます。

お礼日時:2014/07/23 19:27

Visual Basic についての質問でしょうか。


そうでしたら IsNumeric(...) ではないでしょうか。

IsNumber visual basic
とサーチしたら次のようになりました。
Showing results for IsNumeric visual basic
Search instead for IsNumber visual basic
    • good
    • 1
この回答へのお礼

ありがとうございます。

お礼日時:2014/07/23 19:27

お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!

このQ&Aを見た人はこんなQ&Aも見ています


このQ&Aを見た人がよく見るQ&A