前提・実現したいこと
オーバーフロー防止のため、
マクロ使用者がワークシート全体を選択した場合、
メッセージを表示してプロシージャーを終了させたいと思っています。
下記のtest1()の条件文を試したのですが、
シート全体を選択した場合
エラーになってしまいます。
みなさんのお知恵を借りたいと思います。
よろしくお願いします。
発生している問題・エラーメッセージ
実行時エラー'6': オーバーフローしました。
該当のソースコード
VBA
1Sub test1() 2 If Selection.Count > 1000000 Then 3 MsgBox "注意文" 4 Exit Sub 5 End If 6End Sub 7 8Sub test2() 9 MsgBox Cells.Select 10End Sub
試したこと
Cells.Selectがシート全選択のメソッドと知り、
マクロ使用者が全選択を行ったかを戻り値を得られないか試したのですが、
うまくいきませんでした。
その過程で疑問に思ったことがあります。
上記のtest2()を実行するとTrueが返ってくるのですが、
同時にシートが全体選択されています。
なぜMsgBoxの引数であるCells.Selectが動作しているのか疑問です。
冒頭の問題が解決さえすればよいのですが、
後学のために
おわかりの方がいらっしゃれば
教えていただきたいと思います。
補足情報(FW/ツールのバージョンなど)
環境はWindows 7、Excel 2010です。

回答2件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。
2018/04/21 13:53