![Как превратить записанный макрос в автоматизированный макрос в VBA?](https://rvso.com/image/1611746/%D0%9A%D0%B0%D0%BA%20%D0%BF%D1%80%D0%B5%D0%B2%D1%80%D0%B0%D1%82%D0%B8%D1%82%D1%8C%20%D0%B7%D0%B0%D0%BF%D0%B8%D1%81%D0%B0%D0%BD%D0%BD%D1%8B%D0%B9%20%D0%BC%D0%B0%D0%BA%D1%80%D0%BE%D1%81%20%D0%B2%20%D0%B0%D0%B2%D1%82%D0%BE%D0%BC%D0%B0%D1%82%D0%B8%D0%B7%D0%B8%D1%80%D0%BE%D0%B2%D0%B0%D0%BD%D0%BD%D1%8B%D0%B9%20%D0%BC%D0%B0%D0%BA%D1%80%D0%BE%D1%81%20%D0%B2%20VBA%3F.png)
Я записал следующий макрос для сортировки данных в диапазоне «B3:U47» на основе значений столбца «C3:C47».
Sub Sorting_Finance()
Range("B3:U47").Select
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? Я пытаюсь изменить его через VBA, но пока безуспешно.
решение1
Шаблон:
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
И не забудьте удалить/закомментировать Range("B3:U47").Select
строку.