Deleting all rows that meet a certain condition, for multiple files

longtalker

New Member
Joined
Jan 31, 2009
Messages
28
Hi everyone

I have a bunch of spreadsheets in a folder, and all of them need to have the following operation done upon them: whenever a cell in the C column is smaller than -1000 or greater than 1000, then the whole row that contains that cell gets deleted.

Any macro that could do this for all files (and subsequently save&close them)? Also, if it's not too complicated, is there a way for the macro to create a log file with all the rows that were deleted for each file?

Anticipated thanks!
(sorry for cross posting this question on another forum as well, I just need to find a solution to this quite soon)
 

Excel Facts

Move date out one month or year
Use =EDATE(A2,1) for one month later. Use EDATE(A2,12) for one year later.
please put in the post to the cross post so that we don't waste time if someone else has already answered.
 
Upvote 0
Try this, but test it on a copy of your folder. The workbook containing this code becomes the log file and should be saved in a separate folder.

You haven't said which sheet(s) in the workbooks should be checked, e.g. one or all. The code checks the first sheet in each workbook but can be easily changed to check all sheets.
Code:
Public Sub Loop_All_Workbooks_in_Folder()

    Dim folder As String
    Dim filename As String
    Dim logRange As Range
    
    Set logRange = Sheets("Sheet1").Range("A1")     'SHEET AND STARTING CELL IN THIS WORKBOOK IN WHICH THE DELETED ROWS WILL BE LOGGED
    
    folder = "C:\Temp\Excel\"               'FOLDER CONTAINING WORKBOOKS TO BE CHECKED
    
    filename = Dir(folder & "*.xls")
    Do While filename <> vbNullString
        Workbooks.Open folder & filename
        Delete_Rows_in_Workbook logRange
        ActiveWorkbook.Close savechanges:=True
        filename = Dir
    Loop

End Sub


Private Sub Delete_Rows_in_Workbook(logRange As Range)

    Dim lastRow As Long, row As Long
    
    'Look at 1st sheet in workbook
    
    With ActiveWorkbook.Sheets(1)
        lastRow = .Cells(.Rows.Count, "C").End(xlUp).row        
        row = 1
        While row < lastRow
            If .Cells(row, "C").Value < -1000 Or .Cells(row, "C").Value > 1000 Then
                .Cells(row, "C").EntireRow.Copy logRange
                Set logRange = logRange.Offset(1, 0)
                .Cells(row, "C").EntireRow.Delete
            Else
                row = row + 1
            End If
        Wend
    End With
    
End Sub
As a courtesy to the members of the other forums, please post a link to this thread in your other threads.
 
Upvote 0

Forum statistics

Threads
1,224,517
Messages
6,179,239
Members
452,898
Latest member
Capolavoro009

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top