2017-07-17 139 views
0

我想生成一个函数来将数据从一个电子表格拖到另一个电子表格,但不断收到全局方法范围错误。它是第4行产生错误。任何解决方案方法范围失败

Sub potential() 

    'Add hours for potential work to generate function 

    Worksheets("Resource Forecast").Select 

    ***p = Range("Potential Person").End(xlDown).Row - Range("Potential Person").Row*** (error line) 

    Worksheets("Resourcing Sit-Rep").Select 

    For k = 1 To p 

     For j = 1 To 187 
      If Range("hours").Offset(k, j).Value > 0 Then 

      Sheets("Resource Forecast").Select 
       Val5 = Range("person").Offset(k, 1).Value 
       Val6 = Range("person").Offset(k).Value 
       Val7 = Range("hours").Offset(k, j).Value 
       Val8 = Range("date").Offset(0, j).Value 

      Sheets("Resourcing Sit-Rep").Select 
       A = Range("Leader").Offset(0, 2).End(xlDown).Row - Range("Leader").Offset(0, 2).Row + 1 

       Range("Leader").Offset(A, 2).Formula = Sheets("Resource Forecast").Range("Project_Number").Value & " (" & Sheets("Resource Forecast").Range("Project_Name").Value & ") - " & Val5 & " POTENTIAL WORK" 
       Range("Leader").Offset(A, 3).Formula = Val6 
       Range("Leader").Offset(A, 4).Formula = Val7/7.5 
       Range("Leader").Offset(A, 5).Formula = Val8 

      Else 

      End If 

     Next j 

    Next k 
    Range("Leader").Offset(1, 0).Resize(1, 2).AutoFill Destination:=Range("A4", Cells(Range("Leader").Offset(0, 2).End(xlDown).Row, 2)), Type:=xlFillDefault 

End Sub 

回答

0

从该行删除End(xlDown)

,做你想做,你可以使用下面的(使用间接引用)什么:

Range("Area2").Cells(1, 1).Row - Range("Area1").Cells(1, 1).Row - Range("Area1").Rows.Count 

在这里,你只算Area1第一排和Area2第一行之间的行量,那么你从减该区域中的这一行数量。

+0

我现在正在为它上面的行获取下标超出范围吗? –

+0

您是否在'Range'函数中更改了名称(“Area1”...)? –

+0

只是改变范围部分 –