マイクロソフト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
回答3件
あなたの回答
tips
プレビュー