WorksheetBase.CircularReference 属性

获取一个 Range 对象,该对象表示包含表上第一个循环引用的范围,或者,如果表上不存在循环引用,则获取 nullnull 引用(在 Visual Basic 中为 Nothing)。

命名空间:  Microsoft.Office.Tools.Excel
程序集:  Microsoft.Office.Tools.Excel.v4.0.Utilities(在 Microsoft.Office.Tools.Excel.v4.0.Utilities.dll 中)

语法

声明
Public ReadOnly Property CircularReference As Range
    Get
public Range CircularReference { get; }

属性值

类型:Microsoft.Office.Interop.Excel.Range
一个 Range 对象,表示包含表上第一个循环引用的范围,或者,如果表上不存在循环引用,则为 nullnull 引用(在 Visual Basic 中为 Nothing)。

备注

在计算可以继续之前,必须移除循环引用。

示例

下面的代码示例通过将单元格 A1 和 B1 的公式设置为解析为彼此的值来创建循环引用。 然后该示例使用 CircularReference 属性报告工作表是否具有循环引用。

此示例针对的是文档级自定义项。

Private Sub HasCircularReference()
    Me.Range("A1").Formula = "=B1"
    Me.Range("B1").Formula = "=A1"

    If Me.CircularReference Is Nothing Then
        MsgBox("This worksheet has no circular references")
    Else
        MsgBox("The worksheet has a circular reference at: " & _
            Me.CircularReference.Address( _
            ReferenceStyle:=Excel.XlReferenceStyle.xlA1))
    End If
End Sub
private void HasCircularReference()
{
    this.Range["A1", missing].Formula = "=B1";
    this.Range["B1", missing].Formula = "=A1";

    if (this.CircularReference == null)
    {
        MessageBox.Show("This worksheet has no circular references");
    }
    else
    {
        MessageBox.Show("The worksheet has a circular reference at: " +
            this.CircularReference.get_Address(missing, missing,
            Excel.XlReferenceStyle.xlA1, missing, missing));
    }
}

.NET Framework 安全性

请参见

参考

WorksheetBase 类

Microsoft.Office.Tools.Excel 命名空间