Poniższy skrypt działa na mniejszych zestawach danych (mniej niż 30 tys. Wierszy), ale powoduje błędy "#VALUE" dla każdej komórki w wybranym zakresie, gdy zakres jest większy.VBA i Excel: Dlaczego mój skrypt TRIM daje #VALUE na dużych zbiorach danych?
Dim FirstCell As Range, LastCell As Range, MyRange As Range
Set LastCell = Cells(Cells.Find(What:="*", SearchOrder:=xlRows, _
SearchDirection:=xlPrevious, LookIn:=xlValues).Row, _
Cells.Find(What:="*", SearchOrder:=xlByColumns, _
SearchDirection:=xlPrevious, LookIn:=xlValues).Column)
Set FirstCell = Cells(Cells.Find(What:="*", After:=LastCell, SearchOrder:=xlRows, _
SearchDirection:=xlNext, LookIn:=xlValues).Row, _
Cells.Find(What:="*", After:=LastCell, SearchOrder:=xlByColumns, _
SearchDirection:=xlNext, LookIn:=xlValues).Column)
Set MyRange = Range(FirstCell, LastCell)
MyRange.Select
If MyRange Is Nothing Then Exit Sub
Application.ScreenUpdating = False
Application.Calculation = xlCalculationManual
With Selection
.Value = Evaluate("if(row(" & .Address & "),clean(trim(" & .Address & ")))")
End With
Application.ScreenUpdating = True
Application.Calculation = xlCalculationAutomatic
MsgBox "Finished trimming " & vbCrLf & "excess spaces", 64
Ile komórek zmieniasz za pomocą tego kodu? Właśnie przetestowałem to na ~ 1,7 miliona komórek i nie dostałem żadnych błędów w moim dokumencie ćwiczeniowym – TMH8885
8,106,860 komórek. To 161,363 wiersze. –
Wydaje się działać do około 70 tys. Wierszy. Za dużo więcej, po prostu ustawia wartość każdej komórki w wybranym zakresie na #VALUE. –