
マクロを利用して各シートの行を非表示にしたいです。
下記のようにマクロを書いたのですが、実行すると1分ほどかかってしまいます。
マクロ初心者のため、どうしたら早く処理できるように変更できるかわかりません。
複数のシートを同時に実行したいです。
どうすれば早くなるでしょうか。
ご教授願います。
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
Sub sample6()
Application.ScreenUpdating = False
Dim LastRow As Long
Dim i As Long
Dim wst1 As Worksheet
Dim wst2 As Worksheet
Dim wst3 As Worksheet
Dim wst4 As Worksheet
Set wst1 = Worksheets("●")
Set wst2 = Worksheets("▲")
Set wst3 = Worksheets("■")
Set wst4 = Worksheets("★")
LastRow = Cells(Rows.Count, 7).End(xlUp).Row
For i = 28 To 418
If wst1.Cells(i, 7) = 0 Then
wst1.Rows(i).Hidden = True
End If
If wst2.Cells(i, 7) = 0 Then
wst2.Rows(i).Hidden = True
End If
If wst3.Cells(i, 7) = 0 Then
wst3.Rows(i).Hidden = True
End If
If wst4.Cells(i, 7) = 0 Then
wst4.Rows(i).Hidden = True
End If
Next i
Application.ScreenUpdating = True
End Sub
ーーーーーーーーーーーーーーーーーーーーーーーーーーーーーーー
A 回答 (2件)
- 最新から表示
- 回答順に表示
No.2
- 回答日時:
nunohiraさんの書いたマクロ自体に時間のかかる要素はないはずです。
時間がかかるは、そのシートに含まれる計算式の再計算が原因と思われます。
試しに、計算方法を「手動」にしてから、マクロを実行してみてください。
これにより、お望みのパフォーマンスが得られるようであれば、計算方法の
切り替えをマクロに組み込んで下さい。
No.1
- 回答日時:
以下でどうなりますか
Public Sub Samp1()
Dim v As Variant
Dim rng As Range
Dim i As Long
Application.ScreenUpdating = False
For Each v In Array("●", "▲", "■", "★")
With Worksheets(v)
Set rng = Nothing
For i = 28 To 418
If (.Cells(i, 7) = 0) Then
If (rng Is Nothing) Then
Set rng = .Cells(i, 7)
Else
Set rng = Union(rng, .Cells(i, 7))
End If
End If
Next
If (Not rng Is Nothing) Then
rng.EntireRow.Hidden = True
End If
End With
Next
Application.ScreenUpdating = True
End Sub
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Visual Basic(VBA) 【前回の続き続きです、ご教示ください】VBAの記述方法がわかりません。 2 2022/08/24 20:49
- Visual Basic(VBA) シート削除のマクロで「deleteメソッドは失敗しました」となります。助けてください! Sub 不要 6 2022/09/08 16:41
- Visual Basic(VBA) Excel VBA キーワードから列を取得して、さらに空欄行を非表示にする 3 2022/10/21 22:49
- Visual Basic(VBA) ExcelVBAに関する質問 3 2023/02/17 10:47
- Excel(エクセル) VBAの指示の内容 昨日こちらでご教示頂いたのですが初心者な為、一つ一つの指示が何をやっているのかわ 2 2022/10/25 18:08
- Visual Basic(VBA) コード名シートA列と集計シートA列のコードが一致したら、コード名シートA5からk12の範囲をコピーし 1 2022/08/29 23:46
- Excel(エクセル) vba 転記するときの最終行について 2 2022/09/03 09:31
- Visual Basic(VBA) Excel vbaについての質問 3 2023/04/18 16:14
- Excel(エクセル) VBAについて 3 2022/06/19 18:19
- Visual Basic(VBA) 【ご教示ください】VBAの記述方法がわかりません。 2 2022/08/12 21:28
このQ&Aを見た人はこんなQ&Aも見ています
-
エクセルVBAのEntireRow.Hiddenをスピードアップしたいのですが・・・。
Excel(エクセル)
-
特定のセルが空白だったら、その行を非表示にしたい。。。
Visual Basic(VBA)
-
特定のシートのみ再計算させない方法は?
Excel(エクセル)
-
-
4
EXCEL VBA 指定範囲内で特定の列に空白セルを含む行を非表示
Excel(エクセル)
-
5
private subモジュールを他のモジュールから呼び出して使う方法を教えてください(-.-)
Visual Basic(VBA)
-
6
VBAでエクセルシートを更新(リフレッシュ)する方法を教えて下さい。
Excel(エクセル)
-
7
エクセルVBA/イベント発生でコピペ不能はなぜ?
Excel(エクセル)
-
8
EXCELの条件付き書式で数式を空白と認識してくれる方法
Excel(エクセル)
-
9
「Columns(A:C")」の列文字を数字にして表記したい"
Excel(エクセル)
-
10
Excel VBAでのWorksheet_Changeが動作しない原因
Excel(エクセル)
-
11
エクセルで特定の値を含む列のみVBAで非表示にしたい
Excel(エクセル)
-
12
VBA 複数の行を高速で削除する方法
その他(プログラミング・Web制作)
-
13
同じマクロのプログラムなのに処理速度が違う
Visual Basic(VBA)
-
14
【VBA】複数のシートの指定した列を非表示・表示をさせたい
Excel(エクセル)
-
15
EXCEL VBA マクロ 実行する度に処理速度がどんどん遅くなる原因が知りたい
Excel(エクセル)
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
エクセルで特定の列が0表示の場...
-
マクロの連続印刷が突然不可能...
-
特定のPCだけ動作しないVBAマク...
-
ダブルクリックで貼り付けた画...
-
Excelのセル値に基づいて図形の...
-
エクセルでのオブジェクト選択...
-
メッセージボックスのOKボタ...
-
TERA TERMを隠す方法
-
マクロ実行時、ユーザーフォー...
-
エクセルのマクロ(range)につ...
-
【Excel】複数のマクロをまとめ...
-
Excel_マクロ_現在開いているシ...
-
エクセルで縦に並んだデータを...
-
ExcelVBA 図形をクリックした...
-
エクセルVBA イベントプロシー...
-
C#言語でACCESSのソースを取得...
-
マクロ実行時エラー
-
wordを起動した際に特定のペー...
-
【Excel VBA】データ貼り付けの...
-
EXCEL VBAでマクロの最後でFind...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
特定のPCだけ動作しないVBAマク...
-
Excel・Word リサーチ機能を無...
-
エクセルで特定の列が0表示の場...
-
Excel_マクロ_現在開いているシ...
-
一つのTeratermのマクロで複数...
-
メッセージボックスのOKボタ...
-
Excel マクロ VBA プロシー...
-
ExcelのVBA。public変数の値が...
-
エクセルで別のセルにあるふり...
-
エクセルに張り付けた写真のフ...
-
Excel マクロでShearePoint先の...
-
TERA TERMを隠す方法
-
Excelのセル値に基づいて図形の...
-
Excel VBAからAccessマクロを実...
-
ExcelVBAでPDFを閉じるソース
-
マクロ実行時、ユーザーフォー...
-
オートフィルターとExcelマクロ...
-
wordを起動した際に特定のペー...
-
特定文字のある行の前に空白行...
-
エクセルで縦に並んだデータを...
おすすめ情報