A Simple Sort with One Argument
August 12, 2022 - by Bill Jelen
data:image/s3,"s3://crabby-images/ab75c/ab75c5c5c88b009bc697298a790d1a3e1e2c4f99" alt="A Simple Sort with One Argument A Simple Sort with One Argument"
Sorting with a formula in Excel used to require an insane combination of formulas. Take a look at the following data, which is used throughout this example.
data:image/s3,"s3://crabby-images/2ddaa/2ddaa60e1fdb38060ed58db3531ccb2927b0f147" alt="The original data has name in column A, team in column B (either Red or Blue) and Score in column C. Currently, the data is sorted by Name."
To greatly simplify our sorting in such a situation, Joe McDaid and his team have brought us SORT
and SORTBY
.
Let's start with SORT
. Here is the syntax: =SORT(array, [sort_index], [sort_order], [by_col])
.
data:image/s3,"s3://crabby-images/928ac/928acf8c30c5c4d52e76e92152bf3959530f2a07" alt="The syntax for the SORT function is array, sort index, sort order, by column. Only the first argument is required - the others are optional."
Let's say you want to sort A3:C16 by the Score field. Score is the third column in the array, so your sort_index value will be 3.
The choices for the sort_order value are 1 for ascending or -1 for descending. I am not complaining, but there will never be support for sorting by color, formula, or a custom list using this function.
data:image/s3,"s3://crabby-images/5abad/5abad7d9b891d661efb3d24efadda185a5805cc4" alt="So far, the formula says =SORT(A3:C16,3, The tooltip for Sort Order shows that you use 1 for Ascending or -1 for Descending. If you leave this argument off, the default is ascending."
The fourth argument will rarely be used. It is possible in the Sort dialog to sort by columns instead of rows, but 99.9% of people sort by rows. If you need to sort by columns, specify True for the final argument, by_col. This argument is optional and defaults to False.
data:image/s3,"s3://crabby-images/099e1/099e17c64dd063fc55008c6cf95e43d79c0b83d9" alt="The fourth argument is By Column. True will sort by column. False with sort by row. Choosing True here will be equivalent to using Sort Left to Right in the Sort Options dialog box. If you don't use the fourth argument, it defaults to False which does a normal sort of the rows."
Here are the results of the single formula entered, in this case, in cell O2. Thanks to the new calc engine, the formula spills into adjacent cells.
data:image/s3,"s3://crabby-images/be094/be094dde07127947ad0f395099f1aa682f18c10c" alt="The original data is sorted by score descending using a formula of =SORT(A3:C16,3,-1,False)."
A Sort Based on Two or More Columns of Results
What if you need a two-level sort, such as sorting by column two ascending and column three descending? In this case, you supply array constants for the second and third arguments: =SORT(A2:C17,{2;3},{1;-1}).
data:image/s3,"s3://crabby-images/b3933/b393358ff0e445262343f722964c9619d1665171" alt="Can you do a two level sort with the SORT function? You have to use an array constant to pass two values to both the second and third argument. Sort by columns {2;3} and {1;1}. In English, this means sort by column 2 ascending and column 3 descending."
This article is an excerpt from Power Excel With MrExcel
Title photo by Andre Taissin on Unsplash