
オートフィルタを使った不要行削除のExcelマクロを作成したのですが、動作がとても重くなることが頻発します。
Range("A1").Select
Selection.AutoFilter
ActiveSheet.Range("$A$1:$BA$30000").AutoFilter Field:=1, Criteria1:=Array("A", "C", "D")
Range("2:2").Select
Selection.End(xlDown)).Select
Selection.Delete
3万行×50列程度のデータに対して、このようなコードで処理していますが、「A,C,Dでフィルタをかけたときは30秒で処理が終わるのに、A,B,Dでフィルタをかけると5分以上かかる」みたいな現象が起き、原因がわかりません。
コードの改善点を教えてもらえないでしょうか。
A 回答 (1件)
- 最新から表示
- 回答順に表示
No.1
- 回答日時:
「Selection.Delete」を行う際に、次のようにいくつかの作業を止めたら改善しませんか?
--------------------------------------------------------------------------------
Application.ScreenUpdating = False '表示書き換えの停止
Application.Calculation = xlCalculationManual '再計算の停止
Application.EnableEvents = False 'イベント割込みの停止
Selection.Delete
Application.EnableEvents = true 'イベント割込みの再開
Application.Calculation = xlCalculationAutomatic '再計算の再開
Application.ScreenUpdating = true '表示書き換えの再開
--------------------------------------------------------------------------------
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルのVBAで集計をしたい
-
【マクロ】変数に入れるコード...
-
【マクロ】実行時エラー '424':...
-
エクセルのリストについて
-
エクセルの関数について
-
【マクロ】元データと同じお客...
-
【マクロ】左のブックと右のブ...
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
【画像あり】オートフィルター...
-
【マクロ】【配列】3つのシー...
-
他のシートの検索
-
Office2021のエクセルで米国株...
-
vba テキストボックスとリフト...
-
エクセルの複雑なシフト表から...
-
【関数】3つのセルの中で最新...
-
LibreOffice Clalc(またはエク...
-
【マクロ】excelファイルを開く...
-
エクセルシートの見出しの文字...
-
【関数】=EXACT(a1,b1) a1とb1...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
【マクロ】元データと同じお客...
-
エクセルの関数について
-
【画像あり】オートフィルター...
-
エクセルのVBAで集計をしたい
-
エクセルのリストについて
-
【マクロ】数式を入力したい。...
-
【マクロ】【相談】Excelブック...
-
Office2021のエクセルで米国株...
-
【マクロ】実行時エラー '424':...
-
他のシートの検索
-
エクセルの複雑なシフト表から...
-
【マクロ】【配列】3つのシー...
-
vba テキストボックスとリフト...
-
【マクロ】左のブックと右のブ...
-
【マクロ】変数に入れるコード...
-
エクセルシートの見出しの文字...
-
【マクロ】別ファイルへマクロ...
-
【関数】同じ関数なのに、エラ...
-
Amazonでマイクロソフトオフィ...
-
ページが変なふうに切れる
おすすめ情報