エクセルがおかしいです。
ファイルが壊れてるのでしょうか?
Private Sub Worksheet_Change(ByVal Target As Range)
Range("a2") = Empty
Range("a3") = Empty
という、単純なコードなのですが
イベントが発生すると
「メモリ不足です。完全に表示できません。」となったり、
実行時エラー -'-2147417848(80010108)
'_default'メソッドは失敗しました 'range'オブジェクト
となります。
Range("a2") = Empty
の部分で発生します。
そして強制終了され、再起動されます。
コードとしては問題ないですよね?
バージョンは2010です。
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
こんにちは。
>実行時エラー -'-2147417848(80010108)
これは、アプリケーション側のエラーのようですね。
>'_default'メソッドは失敗しました 'range'オブジェクト
プログラムのメモリがどんどん上がっていくようです。
私のExcel 2010 では、一度エラーが出た後は、そのワークブックのみが使えなくなる状態でした。
>Range("a2") = Empty
よく、ここが問題だと分かりましたね。
Empty と入力する時点で、再び、「Private Sub Worksheet_Change」に戻ることは確認できましたか?
>コードとしては問題ないですよね?
入門者としては、#1の方のように、Application.EnableEvent のFalse で、再び、戻らないようにして、終わる時に、True にしてあげればよいのです。
もし、余裕があるなら、以下も読んでみてください、強要はしませんが。
ワークシート側には、実際には、Empty値自体は、存在しないのです。
当たり前のような気がしますが、Empty値というのは、Variant 型の変数に、何も入れない状態か、値がある場合は、Empty値を入れるというように考えています。あくまでも、VBAで使われるものだと思っています。
他にも似たようなものに、Null値というものがあります。
数値型なら、0 で、文字型なら、 ""(長さ0の文字列) ですが、今回の場合は、"" と同等なのです。
つまり、Range("A2").ClearContents と同等なのです。
それから、入門レベルを越えたら、正しく、プロパティ Valueを入れたほうがよいです。
Range("A2").Value = ""
'//(以下は、論理的矛盾は無視します)
Private Sub Worksheet_Change(ByVal Target As Range)
Application.EnableEvents = False
Range("A2").ClearContents
Range("A3").ClearContents
Application.EnableEvents = True
End Sub
No.1
- 回答日時:
Range("a2") = Empty
これがまたchangeイベントをトリガして、一種の無限ループに陥っています。
状況に依ってはエクセルが自動復帰する場合もありますが、スタックオーバーフローで停止したりご質問のケースではエラーになります。
Private Sub Worksheet_Change(ByVal Target As Range)
application.enableevents = false
Range("a2") = Empty
Range("a3") = Empty
application.enableevents = true
end sub
などのような手で、再帰的にならないように工夫します。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- PowerPoint(パワーポイント) ExcelのVBAコードについて教えてください。 3 2022/05/25 14:32
- Excel(エクセル) エクセルVBAでオブジェクトが必要です 2 2022/09/10 16:37
- Visual Basic(VBA) 【VBA】ボタンに登録したマクロがエラーになる 4 2022/07/25 17:47
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 2 2022/05/26 17:19
- Visual Basic(VBA) [Excel VBA] このコードでは行の挿入や行の消去をすると13のエラーが出てしまう。 3 2022/12/09 00:29
- Visual Basic(VBA) Excelマクロでセルに値が入力されたら実行する 5 2023/08/06 11:03
- Visual Basic(VBA) エクセルVBA 3 2022/06/23 20:00
- Visual Basic(VBA) エクセルVBA(実行時エラー438)の対処法を教えてもらえないでしょうか 3 2023/04/22 13:43
- Visual Basic(VBA) ExcelのVBAコードについて教えてください。 1 2023/02/02 09:25
- Visual Basic(VBA) 3つのプロシージャをまとめたら実行時エラー発生で対応不能 6 2022/05/17 01:47
このQ&Aを見た人はこんなQ&Aも見ています
-
性格の違いは生まれた順番で決まる?長男長女・中間子・末っ子・一人っ子の性格の傾向
同じ環境で生まれ育っても、生まれ順で性格は違うものなのだろうか。家庭教育研究家の田宮由美さんに教えてもらった。
-
実行時エラー'-2147417848(80010108)':
その他(Microsoft Office)
-
VBA シートをコピーする際に Copyメソッドは失敗しましたのエラーが出てしまいます
Visual Basic(VBA)
-
エクセルでエラーが出て困っています。
Excel(エクセル)
-
-
4
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
5
VBA シートのボタン名を変更したい
Visual Basic(VBA)
-
6
特定のPCだけ動作しないVBAマクロがあります。その理由は?
Visual Basic(VBA)
-
7
エクセルVBAでフォームのListboxをスクロールするには?
その他(Microsoft Office)
-
8
Application.ScreenUpdating = Falseが効きません
Visual Basic(VBA)
-
9
Rangeメソッドは失敗しました。globalオブジェクトについて
Excel(エクセル)
-
10
ユーザーフォームを表示中にシートの操作をさせるには
Excel(エクセル)
-
11
エクセルVBAで行削除時にエラーが発生します。
Excel(エクセル)
-
12
エクセル:マクロ「Application.CutCopyMode = False」って?
Excel(エクセル)
-
13
[ マクロ ] エラーになったりならなかったりする
Excel(エクセル)
-
14
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
15
マクロの「Rangeメソッドは失敗しました’Globalオブジェクト」エラーの解決方法について
Excel(エクセル)
-
16
【ExcelVBA】マクロの入ったシートをコピーしても新しいシート内でマクロを動作させるには?
Excel(エクセル)
-
17
EXCEL VBAで全選択範囲の解除
Excel(エクセル)
-
18
EXCEL VBA セルに既に入力されている文字に文字を追加する
Excel(エクセル)
-
19
(Excel VBA)シートコピー時マクロはコピーしたくない
Excel(エクセル)
-
20
ExcelVBAにてアプリをタスクマネージャーから強制終了させたいのですが
Visual Basic(VBA)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
実行時エラー 438になった時の...
-
VBAがブレークモードになっ...
-
なぜこんな初歩的なVBAのIf文で...
-
実行時エラー3001「引数が間違...
-
マクロについて教えてください...
-
エクセルエラー13型が一致しま...
-
ExcelVBAで、ユーザー定義型は...
-
VBAでのMATCH関数
-
VB6+SQL サーバー 2000 で 実行...
-
アクセス 実行時エラー3265
-
Application.ActiveInspectorで...
-
【Excel VBA】マクロをボタンに...
-
ExcelVBAでsortしようとしたと...
-
DataGridView からの値取得に関...
-
ExcelVBA Range クラスの Page...
-
Access2000での未定義関数repla...
-
VBSで変数の宣言はできないので...
-
VBS実行時エラー オブジェクト...
-
EXCEL/VBAで、自分のPCだけエラ...
-
EXCEL VBAマクロ中断でデバッグ...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
実行時エラー 438になった時の...
-
エクセルエラー13型が一致しま...
-
【Excel VBA】マクロをボタンに...
-
実行時エラー -'-2147417848
-
マクロについて教えてください...
-
VBAがブレークモードになっ...
-
なぜこんな初歩的なVBAのIf文で...
-
実行時エラー3001「引数が間違...
-
OLEDB.NETで接続できない
-
ExcelVBA Range クラスの Page...
-
EXCEL VBAマクロ中断でデバッグ...
-
ADODB.Streamを使用してUTF-8を...
-
VBS実行時エラー オブジェクト...
-
Outlook.ApplicationをCreateOb...
-
VBSで変数の宣言はできないので...
-
なぜエラーになるのでしょうか...
-
VB6+SQL サーバー 2000 で 実行...
-
VBAでのエラー
-
Application.ActiveInspectorで...
-
Excelで下記のようにマクロを作...
おすすめ情報