Sort by value then delete rows underneath

srosk

Board Regular
Joined
Sep 17, 2018
Messages
132
I have a column with either a value of 1 or blank. The sheet has a header. Is there code that can sort by value in column "Z", find the last row with a value, then just delete all blank rows underneath?

Ty!!
 

Some videos you may like

Excel Facts

How to show all formulas in Excel?
Press Ctrl+` to show all formulas. Press it again to toggle back to numbers. The grave accent is often under the tilde on US keyboards.

My Aswer Is This

Well-known Member
Joined
Jul 5, 2014
Messages
16,762
Office Version
2013
Platform
Windows
So in column Z you have either empty cells or cell with the number 1
And you want to sort the column and delete all blank rows below
Well if we sorted the column all the 1's would come to the top.

So if you now have 45 1's in column Z rows 1 to 45 you want to delete all 1.5 million Rows below the 1's

Is that what you want?
I think that is impossible and why do you want to do that.
 
Last edited:

srosk

Board Regular
Joined
Sep 17, 2018
Messages
132
Basically, I need to delete rows if there is not a value of 1 in column Z.. and I'd like to do that, without running a code that continuously loops. I tried it a different way and on 25k+ rows, it takes forever.
 

Michael M

Well-known Member
Joined
Oct 27, 2005
Messages
18,974
Office Version
2013
Platform
Windows
so you are saying that there is data in the other columns below the last row in col Z ??
If so, which columns will contain extra data ?
 

mikerickson

MrExcel MVP
Joined
Jan 15, 2007
Messages
23,641
How about

Code:
Range("Z:Z").SpecialCells(xlCellTypeBlanks).EntireRow.Delete
 

srosk

Board Regular
Joined
Sep 17, 2018
Messages
132
so you are saying that there is data in the other columns below the last row in col Z ??
If so, which columns will contain extra data ?
So basically, my spreadsheet has 5 tabs on it. There is a main tab and then 4 sub tabs. The macro creates the 4 sub tabs if there is relevant data (if sum of Z:Z > 0, subsequent tab is created).

It then copies all data from the main tab to the sub tabs. There are rows of data that are irrelevant on the sub tabs (where the column Z does not have a value of 1). This is why these columns need to be deleted. I tried just copying over line by line based on column Z = 1, but that proved inefficient. There can be up to 100k lines of data on these tabs, so I need a quick way to eliminate the bad stuff.


To answer your question though, data may be on columns A through Y, for example. But, for these records, if z <> 1, then I need that row deleted. That's why I thought a quick sort by 1, then delete rows beneath would prove to be the most efficient way to accomplish this.
 

Michael M

Well-known Member
Joined
Oct 27, 2005
Messages
18,974
Office Version
2013
Platform
Windows
Try using the previously provided code with modifications to suit.

Code:
Sub MM1()
Application.ScreenUpdating = False
With Columns(26)
    .AutoFilter field:=1, Criteria1:=">" & 1
    .SpecialCells(xlCellTypeVisible).EntireRow.Delete
    .AutoFilter
End With
Application.ScreenUpdating = True
End Sub
 

srosk

Board Regular
Joined
Sep 17, 2018
Messages
132
Thanks Michael. I took mikerickson's code and applied it.. which seemed to work without even using a sort function (YAY!). I applied your code and it appeared to delete my test file headers. I am curious.. what's the difference between the two, and why would MM1 be preferable?

Thanks again for all of your help in this thread, and my several other ones. :)

Try using the previously provided code with modifications to suit.

Code:
Sub MM1()
Application.ScreenUpdating = False
With Columns(26)
    .AutoFilter field:=1, Criteria1:=">" & 1
    .SpecialCells(xlCellTypeVisible).EntireRow.Delete
    .AutoFilter
End With
Application.ScreenUpdating = True
End Sub
 

Watch MrExcel Video

Forum statistics

Threads
1,102,709
Messages
5,488,431
Members
407,638
Latest member
brandynl

This Week's Hot Topics

  • Timer in VBA - Stop, Start, Pause and Reset
    [CODE=vba][/CODE] Option Explicit Dim CmdStop As Boolean Dim Paused As Boolean Dim Start Dim TimerValue As Date Dim pausedTime As Date Sub...
  • how to updates multiple rows in muliselect listbox
    Hello everyone. I need help with below code. code is only chaning 1st row in mulitiselect list box. i know issue with code...
  • Delete Row from Table
    I am trying to delete a row from a table using VBA using a named range to find what I need to delete. My Range is finding the right cell. In the...
  • Assigning to a variable
    I have a for each block where I want to assign the value in column 5 of the found row to the variable Serv. [CODE=vba] For Each ws In...
  • Way to verify information
    Hi All, I don't know what to call this formula, and therefore can't search. I have a spreadsheet with information I want to reference...
  • Active Cell Address – Inactive Sheet
    How to use VBA to get the cell address of the active cell in an inactive worksheet and then place that cell address in a location on the current...
Top