在Excel VBA中,如何测试Excel.Range对象变量是否丢失其引用而不会引发运行时错误424 ..?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了在Excel VBA中,如何测试Excel.Range对象变量是否丢失其引用而不会引发运行时错误424 ..?相关的知识,希望对你有一定的参考价值。

在Excel VBA中,如果变量是Excel.Range,并且删除了它引用的范围,则会丢失其引用。任何访问变量的尝试都会导致Runtime Error 424: object required

Dim rng As Range
Set rng = Sheet1Range("A1")
Sheet1.Rows(1).Delete       'Range has been deleted.
Debug.Print rng.Address()   'Any access attempt now raises runtime error 424.

有没有办法测试这种“丢失参考”状态没有错误处理程序..?

测试Nothing,Vartype()和Typename()都没有用,因为变量仍然是一个Range。我完全阅读了Object浏览器中的所有Excel.Application,但一无所获。也许有一些我忽略的东西......?比如史前版本的Excel中那些奇怪的残余函数之一,比如ExecuteExcel4Macro()..?

我在谷歌搜索了这个问题的答案,但没有找到任何帮助。

编辑:

有些人问我为什么要避免错误处理程序。这是我正常的编程理念,原因有两个:

  • 我确实认识到有时错误处理程序是最快捷的方式,或者唯一的方法。但这不是最优雅的方式。看起来好吧,对我来说很糟糕。这就像白色洗涤栅栏和绘制我的猫的肖像之间的区别。 = - )
  • 我避免错误处理程序的另一个原因是教育。很多时候,在寻找替代方案时,我会发现以前从未知道的属性,程序,对象甚至整个库。在这样做的过程中,我找到了更多的装甲来防御我的代码。
答案

这是一种应该能够解决问题的方法,尽管它不是检查它是否被自己删除的好方法。我认为错误处理可能是你最好的方法。

Sub Example()
    Dim foo1 As Range
    Dim foo2 As Range
    Dim foo3 As Range
    Dim numberOfCells As Long

    Set foo1 = Sheet1.Range("A1")
    Set foo2 = foo1.Offset(1, 0) 'Get the next row, ensure this cell exists after row deletion!
    Set foo3 = Union(foo1, foo2)
    numberOfCells = foo3.Cells.Count

    Debug.Print "There are " & numberOfCells & " cells before deletion"
    Sheet1.Rows(1).Delete

    Debug.Print "There are now " & foo3.Cells.Count & " cells"

    If foo3.Cells.Count <> numberOfCells Then
        Debug.Print "One of the cells was deleted!"
    Else
        Debug.Print "All cells still exist"
    End If
End Sub

此外,这是一个更加面向函数的方法,可能是一个稍微好一点的方法来添加到您的代码库。同样,不理想,但它不应该需要一个错误处理程序。

Private getRange As Range

Sub Example()
    Dim foo         As Range
    Dim cellCount   As Long

    Set foo = Sheet1.Range("A1")
    cellCount = GetCellCountInUnion(foo)
    Sheet1.Rows(1).Delete

    If Not cellCount = getRange.Cells.Count Then
        Debug.Print "The cell was removed!"
    Else
        Debug.Print "The cell still exists!"
    End If

End Sub

Private Function GetCellCountInUnion(MyRange As Range) As Long
    Set getRange = Union(MyRange, MyRange.Parent.Range("A50000")) ‘second cell in union is just a cell that should exist
    GetCellCountInUnion = getRange.Cells.Count
End Function

以上是关于在Excel VBA中,如何测试Excel.Range对象变量是否丢失其引用而不会引发运行时错误424 ..?的主要内容,如果未能解决你的问题,请参考以下文章

在Excel VBA中,如何测试Excel.Range对象变量是否丢失其引用而不会引发运行时错误424 ..?

如何测试 Excel VBA 范围变量以引用整列..?

Excel 在 VBA 中,如何获取 Function 的返回值

如何使用 Excel 中的 VBA 重命名访问表?

Excel,VBA中,如何判断变量是不是包含特定字符串

在excel表中插入一行(或一列)后vba代码如何自动修改?