0
我在下面有下面的代码。而不是使用停滞范围(即,范围(“AF9:AF50”)&范围(AK9:BI50“))我期望实现一个动态范围,该范围从第9行开始,贯穿最后一行数据列。我一直在阅读有关如何设置动态范围,但我无法得到它的工作。任何意见/帮助是极大的赞赏。在VBA中设置动态范围
Private Sub Worksheet_Change(ByVal target As Range)
Dim cell As Range
Dim controlRng As Range, nRng As Range
Set cell = Range("AK9:BI50")
Set controlRng = Range("AF9:AF50")
Set nRng = Intersect(controlRng, target)
Application.EnableEvents = False
If Not nRng Is Nothing Then
Select Case target.Value
Case "No Promotion"
target.Offset(, 1).Value = Range("M" & target.Row).Value
target.Offset(, 4).Value = Range("P" & target.Row).Value
target.Offset(, 9).Value = ""
Case "Promotion"
target.Offset(, 1).Value = ""
target.Offset(, 4).Value = ""
target.Offset(, 9).Value = 0.07
Case "Demotion", "Partner", ""
target.Offset(, 1).Value = ""
target.Offset(, 4).Value = ""
target.Offset(, 9).Value = ""
End Select
End If
If Not Application.Intersect(cell, target) Is Nothing Then
Select Case target.Column
Case 37, 39, 43
target.Offset(, 1).Value = target.Value/Range("V" & target.Row).Value
Case 38, 40, 44
target.Offset(, -1).Value = WorksheetFunction.RoundUp((target.Value * Range("V" & target.Row).Value), -2)
Case 41, 60
target.Offset(, 1).Value = WorksheetFunction.RoundUp((target.Value * Range("V" & target.Row).Value), -2)
Case 42, 61
target.Offset(, -1).Value = target.Value/Range("V" & target.Row).Value
End Select
End If
Application.EnableEvents = True
End Sub
嗨贾里德。我遇到的问题是数据行可能会有所不同。本质上,我需要配置代码来识别最后一行,并通过最后一行数据应用所请求的操作。 – Kelsie