質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

Q&A

解決済

3回答

5508閲覧

VBAでインプットボックスでキャンセルか入力なしの場合ループから抜け出したいがエラーになってしまう

halmichi

総合スコア12

VBA

VBAはオブジェクト指向プログラミング言語のひとつで、マクロを作成によりExcelなどのOffice業務を自動化することができます。

ループ

ループとは、プログラミングにおいて、条件に合致している間、複数回繰り返し実行される箇所や、その制御構造を指します

0グッド

0クリップ

投稿2020/08/10 00:11

マイクロソフト360エクセルのVBAで
A1に年月を入力し、そのまま2345列に日付の数値を入れると年月に日付をセットしてうえで、入力した日付のみ表示するプログラムです。
インプットボックスでキャンセルか、入力なしの場合にループから抜けるようにしたいのですが、型が一致しないというエラーが出てしまいます。代入された値の長さが0ならという条件にしてみています。
その後、1列目に名前を入力していくのですが、その時も同じことをしているつもりですがここは問題なく動くようです。
よろしくお願いいたします。

VBA

1 2Private Sub CommandButton1_Click() 3 4InputYearMonth: 'A1セルに年月を入力させる。日付の形でなければループさせる 5Dim ym As String 6Dim flg As Boolean 7 8 flg = False 9 Do 10 11 ym = InputBox(Prompt:="年月を入力してください", Title:="年月入力") 12 If Len(ym) = 0 Then Exit Sub 13 If IsDate(ym) Then flg = True 14 Loop Until flg = True 15 16Cells(1, 1).Value = ym 17 18InputDays: 19Dim ds As Integer 20Dim dates As Date 21Dim i As Long 22 23 For i = 1 To 4 24 Do 25 flg = False 26 ds = InputBox(Prompt:=i & "日目の日付を入れてください", Title:="日付入力")'ここで止まってしまう 27 If Len(ds) = 0 Then 28 Exit For 29 ElseIf Len(ds) <> 0 Then 30 dates = DateAdd("d", ds - 1, Cells(1, 1).Value) 31 End If 32 If Month(dates) = Month(CDate(ym)) Then flg = True 33 Debug.Print Month(dates) 34 Debug.Print Month(CDate(ym)) 35 If flg = False Then MsgBox "月は変えられません", vbExclamation 36 Loop Until flg = True 37 38 Range(Cells(1, i + 1), Cells(2, i + 1)).Value = dates 39 Cells(1, i + 1).NumberFormatLocal = "d" 40 Cells(2, i + 1).NumberFormatLocal = "aaaa" 41 Next i 42 43Inputpts: '顧客名を入力していく キャンセルか入力なしで終わりか聞く 44Dim pts As String 45Dim Result As Long 46Dim k As Integer 47Dim flg2 As Boolean 48 49 k = 5 50 pts = 0 51 flg2 = False 52 53Do 54 Do 55 pts = InputBox(Prompt:="顧客名を入れてください", Title:="名前入力")'ここで同じような処理をさせているつもり 56 If Len(pts) <> 0 Then 57 Cells(k, 1).Value = pts 58 k = k + 1 59 End If 60 Loop Until Len(pts) = 0 61 62 Result = MsgBox("入力を終了しますか?", vbYesNo + vbExclamation) 63 If Result = vbYes Then 64 flg2 = True 65 End If 66 67Loop Until flg2 = True

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

maisumakun

2020/08/10 00:18

どのようなエラーが出るのですか?
halmichi

2020/08/10 01:14

ありがとうございます。「型が一致しません」というエラーが出ます。
guest

回答3

0

InputBox 関数は戻り値が文字列なので、 Integer 型の変数には結果を受け取れません。
Application オブジェクトの InputBox では Type 引数に 1 を指定すると数値入力ができます。

簡単に使い方を示すと次のようになります。

VBA

1Dim ds As Integer 2ds = Application.InputBox(Prompt:="数値を入力してください", Type:=1) 3If ds = False Then 4 Debug.Print "Canceled" 5 Exit Sub 6End If 7 8Debug.Print "input value=" + ds

他のパラメーターは InputBox 関数と同じように指定できます。
また、 Application.InputBox は、 Typeパラメーターで入力値を数値に指定すると、未入力の状態で OKボタンを押すと数式エラーとなります。
Typeパラメーターに文字列(指定値としては 2)を指定した時、キャンセルボタンを押すと上の例のように False との比較でキャンセルされたかどうかを判定できます。一方で、未入力の状態でOKボタンを押すと空の(長さがゼロの)文字列を受け取れるので、キャンセルと長さがゼロの文字列を入力したことを区別できます。
これは InputBox 関数では実現できないでしょう。

投稿2020/08/10 01:35

ironya

総合スコア454

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

ベストアンサー

InputBox 関数 (Visual Basic for Applications) | Microsoft Docs

ダイアログ ボックスにプロンプトを表示し、ユーザーがテキストを入力するかボタンをクリックするまで待機し、テキスト ボックスのコンテンツが含まれる文字列を返します。

 

ユーザーが [キャンセル] を選択すると、この関数は長さ 0 の文字列 ("") を返します。

InputBox 関数は文字列を返します。

vba

1Dim ds As String

投稿2020/08/10 00:38

hatena19

総合スコア33715

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

halmichi

2020/08/10 01:18

ありがとうございます!
hatena19

2020/08/10 03:29

返す型を限定したいなら、他の方の回答にあるように Application.InputBoxメソッドを使った方がいいですね。
guest

0

InputBoxの戻り値を入れる変数の型を変更すると動作します。

VBA

1Dim ds As Variant 2'Dim ds As Integer

投稿2020/08/10 00:30

TanakaHiroaki

総合スコア1063

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

halmichi

2020/08/10 01:18

ありがとうございます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問