美文网首页精进ExcelEXCELExcel 加油站
线表计划大结局-归零心态

线表计划大结局-归零心态

作者: Excel老崔 | 来源:发表于2019-05-21 22:29 被阅读1次

     前言

    通过前面三章的讲解,估计大家已经掌握了图形的基本使用方法,可以灵活的控制图形的显示位置了,以及颜色了,但是当日期发生改变,需要重新运行一下程序时,线条或图形不会自动删除,所以每运行一次,就会增加一次,最后工作表了堆积了大量的无用图形.所以大家一定要记住,在运行程序前一定要将绘图区域归零,删除绘图区所有的图形,,然后再运行宏命令。

     归零大法

    删掉图形的方法:

    1\手动选择,按住CTRL键,一个个点击图形进行选择,这不是我要讲的

    2\F5,定位条件,对象,确定后,所有的对象元素均被选中,点击DEL全部删除,有可能把不想删除的删掉。

    3\使用鼠标,框选对象,可以将制定某个区域的对象删除,总感觉这个按钮好难找,这个图标的位置在开始\查找与选择下面,如下图所示:

    4\最后,还是回到VBA这里,因为上述方法都存在致命缺陷,不够自动化。

    如下图所示,我只想删除F2:J4里面的图形,其他的图形不变.

    打开vba编辑器,输入系列代码:

    Sub 定位删除图形()

    For Each p In ActiveSheet.Shapes

    If Not Application.Intersect(p.TopLeftCell,Range("F2:J4")) Is Nothing Then

    p.Delete

    End If

    Next

    End Sub

    这个程序是将活动工作表中的每个图形,逐一判断该图形的左上角与单元格区域Range("F2:J4"))是否有交集,如果有,则删除此图形,如果没有交集则放你一马.

    因此可以在画线程序开始时,调用此过程,就不用每次手动删除了.以下是完整程序:包含两个过程“drawlineR1”及“定位删除图形”,运行时把鼠标放在drawlineR1过程中,按下F5,程序首先调用“定位删除图形”子过程,然后再重新绘制图形。

    Sub drawlineR1()

    定位删除图形

    For I = 2 To 4

        Start_x = Cells(I,Cells(I, 4)).Left + (Day(Cells(I, 2)) - 1) / Day(WorksheetFunction.EoMonth(Cells(I,2), 0)) * Cells(I, Cells(I, 4)).Width

        Start_y = Cells(I,Cells(I, 4)).Top + Rows(I).Height / 2

        Finish_x =Cells(I, Cells(I, 5)).Left + Day(Cells(I, 3)) /Day(WorksheetFunction.EoMonth(Cells(I, 3), 0)) * Cells(I, Cells(I, 5)).Width

        Finish_y = Start_y

       ActiveSheet.Shapes.AddLine(Start_x, Start_y, Finish_x, Finish_y).Select

            WithSelection.ShapeRange.Line

             .Weight = 3

               .ForeColor.RGB = vbRed

             End With

    Next

    End Sub

    Sub 定位删除图形()

    For Each p In ActiveSheet.Shapes

    If Not Application.Intersect(p.TopLeftCell,Range("F2:J4")) Is Nothing Then

    p.Delete

    End If

    Next

    End Sub

     按钮关联

    最后,为了更方便的更新程序,可以在工作表中插入一个按钮,关联到vba即可

    在开发工具中找到插入表单控件\按钮

    在弹出的对话框中选择要关联的程序名称,确定即可.

    放置按钮在合适的位置,右键编辑文字,命名为”更新”

    当日期发生变更时,直接点击此按钮就可以啦!

     总结

    至此,线表计划的内容已全部讲完了,同学们能掌握多少,就靠自己啦,俗话说:师傅领进门,修行靠个人.要想孰能生巧,必须多想多练,便无他法。有问题,欢迎在下方评论区留言!也欢迎各位转发、分享、点赞、打赏,我将持续为大家分享我的知识和经验,希望对大家有所帮助。

    相关文章

      网友评论

        本文标题:线表计划大结局-归零心态

        本文链接:https://www.haomeiwen.com/subject/jezszqtx.html