12

我在使用生成参考编号的表格时遇到了问题。但是当我尝试生成参考号时。它有一条错误消息说:

运行时错误“1004”:对象“_Global”的方法“范围”失败

当我点击 Debug button 时,它显示如下代码:

它突出显示代码第 4 行的错误

Sub clearTemplate()
    ' Clear Template Content
    Range(inputTemplateHeader) = NO_ENTRY
    Range(inputTemplateContent) = NO_ENTRY     - (highlighted error)
End Sub

Sub clearRefNo()
    ' Clear cell G2 reference number
    Range(cellRefNo) = NO_ENTRY

    ' Open "Report_ref_no.xls"
    If Not (IsFileOpen) Then Workbooks.Open filename:=ThisWorkbook.Path & "\" & FACCESS

    ' Activate "Report_ref_no.xls"
    Windows(FACCESS).Activate

    ' Access column D
    Range(cellFirstRefNo).Select
    Selection.End(xlDown).Select

    If refNo = Cells(ActiveCell.Row, ActiveCell.Column - 1).Value Then
        ' Log Development Code column
        Cells(ActiveCell.Row, ActiveCell.Column) = NO_ENTRY

        ' Log Issuer column
        Cells(ActiveCell.Row, ActiveCell.Column + 1).Value = NO_ENTRY

        ' Log Date column
        Cells(ActiveCell.Row, ActiveCell.Column + 2).Value = NO_ENTRY
    End If

    ' Save & Close workbook
    ActiveWindow.Close True
End Sub

谁能帮我解决这个问题?我不知道出了什么问题?

4

1 回答 1

30

当您像这样引用 Range 时,它​​被称为非限定引用,因为您没有具体说明该范围在哪个工作表上。非限定引用由“_Global”对象处理,该对象确定您所引用的对象,这取决于您的代码所在的位置。

如果您在标准模块中,则不合格的 Range 将引用 Activesheet。如果您在工作表的类模块中,则不合格的 Range 将引用该工作表。

inputTemplateContent 是一个变量,其中包含对一个范围的引用,可能是一个命名范围。如果您查看该命名范围的 RefersTo 属性,它可能在代码执行时指向除 Activesheet 之外的工作表。

解决此问题的最佳方法是通过指定工作表来避免不合格的 Range 引用。喜欢

With ThisWorkbook.Worksheets("Template")
    .Range(inputTemplateHeader).Value = NO_ENTRY
    .Range(inputTemplateContent).Value = NO_ENTRY
End With

调整工作簿和工作表引用以适应您的特定情况。

于 2012-08-29T12:54:15.353 回答