![](/img/trans.png)
[英]Hide and unhide rows in Excel VBA when specific value in the one cell
[英]Hide/unhide specific objects in Excel with VBA
我想要一个宏来隐藏/取消隐藏标注。
目的是有一个信息按钮,一旦按下显示或隐藏信息标注。
问题是我有其他箭头和形状,我不想隐藏。
使用以下代码(1),我可以隐藏所有对象:
Dim sObject As Shape
For Each sObject In ActiveSheet.Shapes
If sObject.Visible = False Then
sObject.Visible = True
Else
sObject.Visible = False
End If
Next
使用此代码(2),我可以隐藏/取消隐藏特定的标注形状
If ActiveSheet.Shapes("Rectangular Callout 6").Visible = False Then
ActiveSheet.Shapes("Rectangular Callout 6").Visible = True
Else
ActiveSheet.Shapes("Rectangular Callout 6").Visible = False
End If
如何才能让第一个代码(1)通过标注形状运行,就像在第二个代码(2)中一样?
怎么样:
Dim sObject As Shape
For Each sObject In ActiveSheet.Shapes
If Not InStr(sObject.Name, "Callout") = 0 Then sObject.Visible = Not sObject.Visible
Next sObject
希望能帮助到你!
由于visible属性是布尔值,因此可以缩短代码:
Sub InvertAllShapesVisibility(wS As Worksheet)
Dim sObject As Shape
'''Invert visibility of all shapes
For Each sObject In wS.Shapes
sObject.Visible = Not sObject.Visible
Next sObject
End Sub
如何使用它 :
Sub Test1_Selrac()
InvertAllShapesVisibility ActiveSheet
End Sub
对于单一形状:
Sub RevertShapeVisibility(wS As Worksheet, ShapeName As String)
Dim sObject As Shape
'''Invert visibility of all shapes containing the KeyWord
For Each sObject In wS.Shapes
If sObject.Name = ShapeName Then sObject.Visible = Not sObject.Visible
Next sObject
End Sub
如何使用它 :
Sub Test2_Selrac()
RevertShapeVisibility ActiveSheet, "Rectangular Callout 6"
End Sub
对于包含关键字的多个形状:
Sub RevertCalloutsVisibility(wS As Worksheet, KeyWord As String)
Dim sObject As Shape
'''Invert visibility of one shape
For Each sObject In wS.Shapes
If Instr(1,sObject.Name,KeyWord) Then sObject.Visible = Not sObject.Visible
Next sObject
End Sub
如何使用它 :
Sub Test3_Selrac()
RevertCalloutsVisibility ActiveSheet, "Rectangular Callout"
End Sub
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.