Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
ErrorTrap1:
On Error GoTo 0
Do
On Error GoTo ErrorTrap2
'-エラーの発生するコード 2
On Error GoTo 0
Loop
ErrorTrap2:
End Sub
しかし、以下のようにSubで二つに分けるとエラーは出ません。
Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
ErrorTrap1:
On Error GoTo 0
Call Macro2
End Sub
Sub Macro2()
Do
On Error GoTo ErrorTrap2
'-エラーの発生するコード 2
On Error GoTo 0
Loop
ErrorTrap2:
End Sub
「On Error GoTo 0」がうまく解除できていないのかと思い、いろいろ試してみました。
しかし、どういった理由かはわかりませんでした。
「On Error GoTo」は、Subでは、ひとつしか使えないのでしょうか。
No.2ベストアンサー
- 回答日時:
エラー処理の中でOn Error GoToを記述することはできません。
エラー処理の基本的な構造は、
Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
On Error GoTo 0
Exit Sub
ErrorTrap1:
'エラー処理
Resume Next
End Sub
エラー処理が2つある場合は、
Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
On Error GoTo 0
Do
On Error GoTo ErrorTrap2
'-エラーの発生するコード 2
On Error GoTo 0
Loop
Exit Sub
ErrorTrap1:
'エラー処理1
Resume Next
ErrorTrap2:
'エラー処理2
Resume Next
End Sub
Resume Next でエラーが発生した行の次の行から再開します。
Resumeには他の構文もありますので、調べてみてください。
No.1
- 回答日時:
>「On Error GoTo」は、Subでは、ひとつしか使えないのでしょうか。
違います。
On Error Goto で飛んだあとの、エラー処理ルーチンでは、ResumeするかExit Subするまでの間、On Error文は一切無視されます。
そして、エラー処理中は、すべてのエラーがシステムによりトラップされ、On Error Goto 0を行ったのと同様に、システムによるエラー表示が行われます。
なお、エラートラップは「関数ごと」に処理される為、エラートラップ中に関数を呼ぶと、呼ばれた関数の中にあるOn Error文は正常に機能します。
従って、質問者さんが書いたプログラムは、
Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
ErrorTrap1:
Do
'-エラーの発生するコード 2 ←ここのエラーはシステムが通常のエラー表示を行う。
Loop
ErrorTrap2:
End Sub
と同等です。2つに分けた場合も
Sub Macro1()
On Error GoTo ErrorTrap1
'-エラーの発生するコード 1
ErrorTrap1:
Call Macro2
End Sub
Sub Macro2()
Do
On Error GoTo ErrorTrap2 ←このOn Error Gotoは、Macro1とは無関係なので、正常に機能する
'-エラーの発生するコード 2
On Error GoTo 0
Loop
ErrorTrap2:
End Sub
と同等です。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【VBAエラー】Nextに対するForがありません 対策について 5 2022/11/21 21:26
- Visual Basic(VBA) Changeイベントで複数セルへの貼り付けおよび値削除時に1個目のセルのみエラーになる 3 2022/12/21 09:07
- Visual Basic(VBA) 複数シートの複数列に入力されているデータを重複なしで抽出するVBAを作りたいです。 9 2022/06/17 10:33
- Visual Basic(VBA) でシートをコピーしたときに 見えないようにする方法 1 2022/04/10 20:27
- Visual Basic(VBA) VBAで重複した値のセルに色付けをしたい 1 2022/11/02 16:12
- Visual Basic(VBA) 【VBAで、On Error が効かない】 3 2022/06/09 10:08
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/08/09 10:33
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
- Visual Basic(VBA) 標準モジュール Public mOnTime As Date Sub sample() '実行プロシ 1 2023/02/22 15:44
関連するカテゴリからQ&Aを探す
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
String""から型'Double'への変...
-
F9キーを実行するVBスクリ...
-
エクセル関数式=ABSで#VALUE!...
-
マクロで"#N/A"のエラー行を削...
-
ApplicationとWorksheetFunctio...
-
現在、QueryTableが設定されて...
-
Python openpyxlを使用したセル...
-
VBA GoTo Error 処理が上手くい...
-
WindowsでのPythonの挙動について
-
Excel vbaについての質問
-
【VBA】ワークブックを開く時に...
-
UWSCでエラー発生時の対処法に...
-
VBA データ(特定値)のある最...
-
#N/Aの文字を削除するには
-
筆王画面が終了できない
-
実行時エラー'-2147467259(8000...
-
Maximaでのエラーメッセージ
-
IMEの単語登録について
-
paizaで下記コードを提出すると...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
String""から型'Double'への変...
-
マクロで"#N/A"のエラー行を削...
-
VBAでfunctionを利用しようとし...
-
文字列内で括弧を使うには
-
実行時エラー 438 の解決策をお...
-
エクセル関数を教えてください
-
On ErrorでエラーNoが0
-
お助けください!VBAのファイル...
-
VBA データ(特定値)のある最...
-
【VBA】ワークブックを開く時に...
-
インポート時のエラー「データ...
-
実行時エラー'-2147467259(8000...
-
マクロの「SaveAs」でエラーが...
-
WindowsでのPythonの挙動について
-
ApplicationとWorksheetFunctio...
-
Excel vbaについての質問
-
エクセルVBA 「On Error GoTo...
-
Filter関数を用いた結果、何も...
-
ACCESSで値を代入できないとは?
おすすめ情報