隐藏行excel vba在未触发时不起作用

时间:2014-09-23 23:12:28

标签: excel excel-vba rows hidden vba

我有一个宏在onchange事件触发时效果很好。它只是检查单元格值并隐藏或取消隐藏同一活动工作表上其他位置的行。这是隐藏或取消隐藏行的宏:

Sub ToggleTaskTable()

MsgBox "Toggling Tasks"

        If Cells(56, 3).Value = "No" Then
            Cells(57, 1).EntireRow.Hidden = 
            MsgBox "Hding Rows 106, 148 and 190"

            ActiveSheet.Rows("106").Hidden = True
            ActiveSheet.Rows("148").Hidden = True
            ActiveSheet.Rows("190").Hidden = True

' try it another way

            Rows("106").Hidden = True
            Rows("148").Hidden = True
            Rows("190").Hidden = True

        Else
            Cells(57, 1).EntireRow.Hidden = False

           '  MsgBox "Showing task Rows 106, 148 and 190"

            Rows("106").Hidden = False
            Rows("148").Hidden = False
            Rows("190").Hidden = False
       End If
End Sub

如果我将单元格C56更改为"否"而调用宏,则效果非常好。

Private Sub Worksheet_Change(ByVal Target As Range)
   If Target.Address = "$C$56" Then
      Call ToggleTaskTable
   End If
End Sub

如果我从另一个宏调用宏,C56设置为"否",它根本不起作用。

Sub CallAllMacros()
   Call ToggleTaskTable
End Sub

即使msgbox显示它表明它正在隐藏行,但它实际上并没有隐藏它们。

我完全被难过了!

1 个答案:

答案 0 :(得分:0)

Sub ToggleTaskTable()
    With ActiveSheet
        .Range("A57,A106,A148,A190").EntireRow.Hidden = (.Cells(56, 3).Value = "No")
    End With
End Sub