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

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

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

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

Q&A

解決済

2回答

645閲覧

後から挿入したコードが処理されない

Khaan_bank

総合スコア4

VBA

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

0グッド

0クリップ

投稿2022/09/10 23:07

編集2022/09/10 23:51

前提

初心者です。
コマンドボタンを押すと元データを集計してメッセージボックスに表示させるコードを書いて正しい結果が表示されています。
それに追加で、元データに空白があった時にそれを知らせるメッセージを表示させて、それ以上先の処理に進まないようにしたいです。

困っていること

下記のコードを単体で実行すると正しい結果が表示されます。
ただ、もともとある「コマンドボタンを押すと元データを集計してメッセージボックスに表示させるコード」の中に埋め込むとその処理がスルーされてしまいます。

順番としては
①変数を宣言

②元データに空白があることを知らせるループ(下記コードを挿入した)

③元データを集計してメッセージボックスに表示(本処理)

以上のような流れになっています。
もともと①→③で正しく機能していました。
②単体では正しい結果が返されますが、
もとのコードに挿入しても②の処理を飛ばしてしまいます。

原因がわからないのですが、教えてもらえると助かります。

該当のソースコード

VBA

1 Sub CommandButton1_Click() 2 3 Dim WEM As String 4 Dim Pa As String 5 Dim i As Long 6 Dim j As Long 7 8 9 WEM = CLng(DateValue(TextBox1.Value)) & "WE" 10 Pa = CLng(DateValue(TextBox1.Value)) & "a" 11 12 For i = 2 To Cells(Rows.Count, 1).End(xlUp).Row 13 For j = 5 To 10 14 If Worksheets("form1").Cells(i, j).Value = "" Then 15 MsgBox "form1に抜けがあります。正しく入力してください。" 16 Exit Sub 17 End If 18 Next 19 Next 20 21 On Error GoTo ErrorHandler '日付が正しく入力されないとエラーになるので ErrorHandlerに飛ぶ 22 MsgBox "報告全数 : " & WorksheetFunction.SumIf(Range("b:b"), Cells(2, 11), Range("d:d")) & vbCrLf & _ 23 "出席者数 : " & _ 24 WorksheetFunction.VLookup(WEM, Worksheets("form2").Range("C:J"), 8, False) & vbCrLf & _ 25 "----------------------------" & vbCrLf & _ 26 "Paの数 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 4, False) & vbCrLf & _ 27 "Pa1 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 5, False) & vbCrLf & _ 28 "Pa2 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 6, False) & vbCrLf & _ 29 "Pa3 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 7, False) & vbCrLf & _ 30 "Pa4 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 8, False) & vbCrLf & _ 31 "Pa5 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 9, False), vbOKOnly, “ Pa " & Format(TextBox1.Value, "yyyy年mm月") 32 Exit Sub 33ErrorHandler: 34 MsgBox "年月日が正しく入力されませんでした" 35End Sub

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

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

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

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

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

hatena19

2022/09/10 23:40

提示のものには「元データを集計してメッセージボックスに表示させるコード」が含まれてません。 それも含めたコードに修正してください。(Sub から End Sub まで) あと、空白セルが見つかった時は、③ の集計処理はしないということでいいでしょうか。
Khaan_bank

2022/09/10 23:52

すみません。修正しました。 >>空白セルが見つかった時は、③ の集計処理はしないということでいいでしょうか。 はい。そういう動きをしてもらいたいです。
guest

回答2

0

ベストアンサー

とりあえず、書き換えてみました。

vba

1Sub CommandButton1_Click() 2 3 Dim WEM As String 4 Dim Pa As String 5 Dim i As Long 6 Dim j As Long 7 8 Worksheets("form1").Select 9 10 If WorksheetFunction.CountBlank(Range(Cells(2, 5), Cells(Cells(Rows.Count, 1).End(xlUp).Row, 10))) > 0 Then 11 MsgBox "form1に抜けがあります。正しく入力してください。" 12 Exit Sub 13 End If 14 15 If Not IsDate(TextBox1.Value) Then 16 MsgBox "年月日が正しく入力されてません" 17 Exit Sub 18 End If 19 20 WEM = CLng(DateValue(TextBox1.Value)) & "WE" 21 Pa = CLng(DateValue(TextBox1.Value)) & "a" 22 23 MsgBox "報告全数 : " & WorksheetFunction.SumIf(Range("b:b"), Cells(2, 11), Range("d:d")) & vbCrLf & _ 24 "出席者数 : " & _ 25 WorksheetFunction.VLookup(WEM, Worksheets("form2").Range("C:J"), 8, False) & vbCrLf & _ 26 "----------------------------" & vbCrLf & _ 27 "Paの数 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 4, False) & vbCrLf & _ 28 "Pa1 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 5, False) & vbCrLf & _ 29 "Pa2 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 6, False) & vbCrLf & _ 30 "Pa3 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 7, False) & vbCrLf & _ 31 "Pa4 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 8, False) & vbCrLf & _ 32 "Pa5 : " & WorksheetFunction.VLookup(Pa, Range("A:I"), 9, False), vbOKOnly, " Pa " & Format(TextBox1.Value, "yyyy年mm月") 33 34End Sub

修正したところは、
念のためにform1を選択しておく
空白のチェックは CountBlank 関数にまかせた。
日付が正しいかどうかをIsDate関数でチェックした

投稿2022/09/11 00:59

編集2022/09/11 01:03
hatena19

総合スコア33699

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

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

0

処理を同一シートで行うようコードを書き換えてみました。

VBA

1With Worksheets("form1") 2 For i = 2 To .Cells(.Rows.Count, 5).End(xlUp).Row 3 For j = 5 To 10 4 If .Cells(i, j).Value = "" Then 5 MsgBox "form1に抜けがあります。正しく入力してください。" 6 Exit Sub 7 End If 8 Next 9 Next 10End With

投稿2022/09/10 23:44

TanakaHiroaki

総合スコア1063

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問