Excel VBA: 一键删除表格中所有图形、图片

Excel表格中插入图形、图片,有时能增强可读性,但插入过多难以管理,而且会导致Excel文件过大,打开速度明显变慢。如果不想再保留这些图形、图片,可以使用以下VBA宏一键删除表格中所有图形、图片,包括隐藏的图形、图片。

直接上代码:

Sub DelAllShapes()
''' delete all shapes in the workbook

    Dim sht As Worksheet
    Dim shp As Shape
    Dim m&, n&
    m = 0
    n = 0
    For Each sht In ActiveWorkbook.Sheets
        Debug.Print sht.Name & ": " & sht.Shapes.Count
        sht.Unprotect
        For Each shp In sht.Shapes
            m = m + 1
            On Error Resume Next
            Err.Clear
            shp.Locked = True
            shp.Visible = msoTrue
            shp.Delete
            If Err.Number <> 0 Then
                n = n + 1
                Debug.Print ("Error # " & Err.Number & " is generated by " & Err.Source & ": " & Err.Description)
            End If
            On Error GoTo 0
        Next
    Next
    
    Debug.Print "Totally " & m & " Shapes, " & n & " failed."

End Sub

当然,也可以增加对Shape.Type的判断,来删除指定类型的Shape。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值