更快的VBA隐藏行

Eri*_*lui 4 excel vba excel-vba

我有一个代码,如果该行中的单元格为零(或为空),则检查每一行.如果行适用于该规则,则该行将被隐藏.如果不是它仍然可见.

代码工作得很好,但速度非常慢(每次运行大约需要40秒)...

我想知道是否有人能够看到为什么我的代码很慢(或者有一个我可以使用的替代品,它比我当前的代码更快)..

 Sub hide()
' Macro hides all rows with position "zero" or "blank"

    Dim wb As Workbook
    Dim ws As Worksheet
    Dim c As Range
    Dim targetRange As Range

    Set wb = ThisWorkbook
    Set ws = wb.Sheets("Sheet 1")
    Set targetRange = ws.Range("I10:N800")

    targetRange.EntireRow.Hidden = False

    For Each c In targetRange.Rows
       If (WorksheetFunction.CountIf(c, "<>0") - WorksheetFunction.CountIf(c, "") = 0) And (WorksheetFunction.CountA(c) - WorksheetFunction.Count(c) = 0) Then
       c.EntireRow.Hidden = True
       End If
    Next c


End Sub
Run Code Online (Sandbox Code Playgroud)

Sha*_*ado 7

每次在工作表上执行操作时,代码中执行操作的时间最多,在您隐藏每一行(多次)的情况下,此处:

c.EntireRow.Hidden = True
Run Code Online (Sandbox Code Playgroud)

为了节省时间,每次满足条件时,只需将范围添加c到a MergeRng,最后(退出循环时),只需一次隐藏整行.

请尝试以下代码:

Dim MergeRng As Range ' define range object

For Each c In targetRange.Rows
    If (WorksheetFunction.CountIf(c, "<>0") - WorksheetFunction.CountIf(c, "") = 0) And (WorksheetFunction.CountA(c) - WorksheetFunction.Count(c) = 0) Then
        If Not MergeRng Is Nothing Then
            Set MergeRng = Application.Union(MergeRng, c)
        Else
            Set MergeRng = c
        End If
    End If
Next c

' hide the entire rows of the merged range at one time
MergeRng.EntireRow.Hidden = True
Run Code Online (Sandbox Code Playgroud)

  • 我使用`Set mrg=Union(IIf(mrg Is Nothing, rng, mrg), rng)`来处理空范围的并集。(只是一个提示/意见!) (2认同)