Excel Sort With a Formula Using SORT and SORTBY
September 25, 2018 - by Bill Jelen
data:image/s3,"s3://crabby-images/03b76/03b760eace3dec3aa365f51d98efca11e9bcc1ee" alt="Excel Sort With a Formula Using SORT and SORTBY Excel Sort With a Formula Using SORT and SORTBY"
This week at the Ignite Conference in Orlando Florida, Microsoft debuted a series of new, easier array formulas in Excel. I will be covering these new formulas every day this week, but if you would like to read ahead:
- Monday covered the new =A2:A20 formula, the SPILL error, and the new SINGLE function required in place of Implicit Intersection
- Today will cover SORT and SORTBY
- Wednesday will cover FILTER
- Thursday will cover UNIQUE
- Friday will cover SEQUENCE and RANDARRAY functions
Sorting with a Formula in Excel used to require an insane combination of formulas. Take a look at this data which will be used throughout this article.
data:image/s3,"s3://crabby-images/3685d/3685d6745403b868ce3a6d7634dea0e7b70335c9" alt="Data in A3:C11"
In order to sort this with a formula before this week, you would just have to knock out RANK, COUNTIF, MATCH, INDEX and INDEX. Once you finished this set of formulas, you would be ready for a nap.
data:image/s3,"s3://crabby-images/ea13c/ea13cb4d03a48857a8acdb98e7e2f90edfae47c1" alt="The old way to sort with a formula"
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 Column])
data:image/s3,"s3://crabby-images/dc96c/dc96c5546bd7688632b14a558b828fedc5f67157" alt="The SORT Function"
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 will be 3.
The choices for the Sort Order are 1 for ascending or -1 for descending. I am not complaining, but there will never be support for Sort by Color, Sort by Formula, or Sort by Custom List using this function.
data:image/s3,"s3://crabby-images/b8374/b8374f9e32057718ea25a58e4c70f2f46449c846" alt="Specify 3 as the sort column and -1 as the sort order for descending."
The forth argument is going to be rarely used. It is possible in the Sort dialog to sort by column instead of rows. 99.9% of people sort by rows. If you need to sort by column, specify True in the final argument. This argument is optional and defaults to False.
data:image/s3,"s3://crabby-images/d146f/d146fae6d964a123609241d881006ec4a19bbb50" alt="If you need to sort by columns, use True in the 4th argument"
Here are the results of the formula. Thanks to the new calc engine, the formula spills into adjacent cells. One formula in O2 produces this solution.
data:image/s3,"s3://crabby-images/c8ab6/c8ab6525556abffb9cd1851405be353b5b2308fa" alt="The original data is sorted"
What if you need a two-level sort? Sort by column 2 ascending and column 3 descending? Supply an array constant for the 2nd and 3rd arguments: =SORT(A2:C17,{2;3},{1;-1})
data:image/s3,"s3://crabby-images/e3016/e30160cddcccdab04aff0f8d905927390ee43c70" alt="Two-level sort"
The SORTBY function lets you sort by something not in the results
The SORTBY function syntax is =SORTBY(array, by_array1, sort_order1,)
data:image/s3,"s3://crabby-images/4e7ee/4e7ee327d2ded4d5d50aca45557abe7b205aa42e" alt="SORTBY something else"
Going back to the original data. Say you want to sort by Team then Score, but only show the names. You could use SORTBY as shown here.
data:image/s3,"s3://crabby-images/7e9f9/7e9f9c5e946ee8e4b4174a80f6e76c3264498ae9" alt="Sort column A by column B and column C"
Random Drug Testing and Random With No Repeats
Difficult scenarios like Random Drug Testing and Random with No Repeats become mind-numbingly simple when you combine SORT with RANDARRAY.
In the figure below, you want to sort the 13 names randomly without repeats. Use =SORTBY(A4:A16,RANDARRAY(13))
. Read more about RANDARRAY on Friday.
data:image/s3,"s3://crabby-images/519c2/519c28a318c977e57263452e5b38c633c82b2303" alt="Sorting randomly without repeats"
Is Ctrl + Shift + Enter completely dead? No. There is still a use for it. Let's say you wanted only the top 3 results from the SORT function. You could select three cells, type the SORT function and follow it with Ctrl + Shift + Enter. This will prevent the results from spilling beyond the bounds of the original formula.
data:image/s3,"s3://crabby-images/a1aae/a1aaeffe589f966e8f0600004312e644caf9546c" alt="Ctrl + Shift + Enter"
Watch Video
Download Excel File
To download the excel file: excel-sort-with-a-formula-using-sort-and-sortby.xlsx
Excel Thought Of the Day
I've asked my Excel Master friends for their advice about Excel. Today's thought to ponder:
"there is no need for a mouse when using excel."
Title Photo: Farsai C. on Unsplash