我已录制以下宏,以根据“C3:C47”列的值对“B3:U47”范围内的数据进行排序。
Sub Sorting_Finance()
ActiveWorkbook.Worksheets("Finance").Sort.SortFields.Clear
ActiveWorkbook.Worksheets("Finance").Sort.SortFields.Add2 Key:= _
Range("C3:C47"), SortOn:=xlSortOnValues, Order:=xlDescending, DataOption _
:=xlSortNormal
With ActiveWorkbook.Worksheets("Finance").Sort
.SetRange Range("B3:U47")
.Header = xlGuess
.MatchCase = False
.Orientation = xlTopToBottom
.SortMethod = xlPinYin
.Apply
End With
End Sub
每次我想对数据进行排序时,我都会按 Control+n。为了在 C 列中输入新值时自动完成此操作,我尝试了以下代码:
Private Sub Worksheet_Change(ByVal Target As Range)
if not (intersect(target, Range("C3:C47")) is nothing) then
call Sorting_Finance
end if
end sub
但事实上,“C3:C47”列中的数据来自另一张表,因此不起作用。我能做些什么吗?
答案1
VBA 排序有两种方法。录制的版本是“普通”版本。您可以使用“简写”版本并设置主要排序顺序列,同时调整范围以适应当前数据。
顺便说一句,您应该知道您是否有标题行。xlGuess 应该替换为 xlYes 或 xlNo,我使用了 xlYes。
在模块1中:
Option Explicit
Sub Sorting_Finance()
With ThisWorkbook.Worksheets("Finance")
'range B3 to column U down to the last row with data in C
With .Range(.Cells(3, "B"), .Cells(.Rows.Count, "C").End(xlUp).Offset(0, 18))
.Sort Key1:=.Columns(2), Order1:=xlAscending, _
Header:=xlYes, Orientation:=xlTopToBottom
End With
End With
End Sub
在财务工作表代码表中,使用相同的方法定义相交范围。
Option Explicit
Private Sub Worksheet_Change(ByVal Target As Range)
If Not Intersect(Target, Range(Cells(3, "C"), Cells(Rows.Count, "C").End(xlUp))) Is Nothing Then
Application.EnableEvents = False
Call Sorting_Finance
Application.EnableEvents = True
End If
End Sub
由于您在重新排序时更改了值,因此请禁用事件处理,以便一次迭代不会在另一次迭代之上运行。