on error goto での処理ルーチン内で、
さらに on error goto を出すことは可能でしょうか。
それとも、一度on errorを設定すると、エラーが発生した後では変更は不可なのでしょうか。
やりたいことは、
1回目と、2回目、3回目以降でやることとを変えたいのです。
例えば、メッセージを変えるとか。
この場合、
エラー処理の中で、何回目かを聞くことで、メッセージを変えることは出来ると思うのですが、
それはやらず、
他にも色々やることが多いので、別処理として飛びたいのです。
以下のようなイメージです。
err1:
on error goto err2
resume next
err2:
on error goto err3
resume next
err3:
resume next
宜しくお願いします。
No.2ベストアンサー
- 回答日時:
ご質問の直接の回答としては、on error gotoでエラー処理ブロックに一度入ったら、そこからresumeしない限り2度目は絶対にありません。
そのためエラー処理の中で(resumeする前に)新たなon error gotoを宣言する事も、それ自体が無効なので出来ません。
一体何のエラーをそんなに頻発しているのか(そこからどういう具合にリカバリしたいのか)は別に質問したくないご様子なので、具体的な対処方法についても回答はしませんが(多分他の対処もありますが)、素直にエラー処理部に入る都度エラー回数カウンターを1回ずつカウントアップして、いま何回目やってきたのか見ながら「共通の1か所のエラー処理ルーチンの中」で処置を分岐したほうが、とりあえず今アナタがヤリタイと思ってる事よりは遥かに簡単に「実現可能」です。
早速有り難うございました。
>ご質問の直接の回答としては、on error gotoでエラー処理ブロックに一度入ったら、
>そこからresumeしない限り2度目は絶対にありません。
>そのためエラー処理の中で(resumeする前に)新たなon error gotoを宣言する事も、
>それ自体が無効なので出来ません。
が聞きたかったのです。
特に現在何をやるためということはなく、ケーススタディをしています。
お世話になりました。
No.1
- 回答日時:
Sub ine()
Dim errCount As Integer
Dim i As Integer
On Error GoTo errH
For i = 1 To 3
Err.Raise 11 '除算エラー
Next
Exit Sub
errH:
errCount = errCount + 1
Err.Clear
MsgBox errCount
Resume Next
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) ExcelのVBAコードについて教えてください。 1 2023/08/09 10:33
- Visual Basic(VBA) VBAで重複した値のセルに色付けをしたい 1 2022/11/02 16:12
- Excel(エクセル) 2つのVBAを一緒にしたら機能しなくなりました(エクセル) 7 2022/06/02 12:41
- その他(パソコン・周辺機器) dvd書き込めない 5 2022/03/22 19:06
- Visual Basic(VBA) 【VBAで、On Error が効かない】 3 2022/06/09 10:08
- Visual Basic(VBA) 【追加】ファイルを閉じてダイアログで保存した時だけ処理の実行をする 3 2022/03/23 15:43
- Visual Basic(VBA) VBAでの共有パスにつきまして 1 2023/03/04 17:24
関連するカテゴリからQ&Aを探す
おすすめ情報
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセル関数を教えてください
-
UserForm1.Showでエラーになり...
-
エクセルVBA 「On Error GoTo...
-
ACCESS VBAのSplit()関数の使用...
-
マクロの「SaveAs」でエラーが...
-
Excel vbaについての質問
-
ステートメントが見つかりません
-
実行時エラー 438 の解決策をお...
-
VBScriptのエラー処理について
-
「実行時エラー '3167' レコー...
-
JAVA Jasper Report でのQRコー...
-
VBでSQL文のUPDATE構文を使った...
-
マクロで"#N/A"のエラー行を削...
-
お助けください!VBAのファイル...
-
Unityのエラー「Rigidbody.AddF...
-
エクセルVBAで埋め込みグラフ(C...
-
VBスクリプトでIEの404 not fou...
-
ある1人の友達のLINEで、少しの...
-
EXCELのVBAの中でMOD関数を使う...
-
エクセルVBAで#N/Aのようなエ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
UserForm1.Showでエラーになり...
-
String""から型'Double'への変...
-
VBAでfunctionを利用しようとし...
-
お助けください!VBAのファイル...
-
文字列内で括弧を使うには
-
実行時エラー 438 の解決策をお...
-
マクロで"#N/A"のエラー行を削...
-
On ErrorでエラーNoが0
-
エクセルVBA 「On Error GoTo...
-
VBA データ(特定値)のある最...
-
実行時エラー'-2147467259(8000...
-
【VBA】ワークブックを開く時に...
-
VBでSQL文のUPDATE構文を使った...
-
ACCESSで値を代入できないとは?
-
マクロの「SaveAs」でエラーが...
-
Excel vbaについての質問
-
インポート時のエラー「データ...
-
Filter関数を用いた結果、何も...
-
「実行時エラー '3167' レコー...
-
バッチファイルで、あるスクリ...
おすすめ情報