Google Sheets offers three powerful functions for advanced sorting capabilities: SORT, SORTN, and QUERY. These functions allow you to sort data in Google Sheets efficiently. Additionally, there’s the SORT menu option for basic sorting. This tutorial explains how to sort data in Google Sheets using these functions, including different formulas and sort orders.
Sort Orders: Ascending and Descending
In Google Sheets, you can sort structured tables, ranges, single columns, or distant columns in ascending (A-Z) or descending (Z-A) order using the SORT, QUERY, or SORTN functions.
- Ascending Order: Lowest values appear at the top of the column.
- Descending Order: Highest values appear at the top of the column.
Empty cells are treated differently depending on the function used:
- SORT and SORTN place empty rows at the bottom, regardless of sort order.
- QUERY places empty rows at the top in ascending order and at the bottom in descending order. However, it has an option to filter out empty rows.
- Additionally, QUERY allows you to keep the header row at the top, whereas SORT and SORTN move it based on the sorting order. When using SORT or SORTN, exclude the header row to prevent it from being sorted.
Sorting Data in a Range in Google Sheets
Let’s say you have fruit names in Column A and their quantities in Column B within the range A1:B10 , with headers in the first row. Some fruits are repeated.
Goal: Sort the range by fruit names in ascending order. If fruits are repeated, sort by quantity in descending order.
Using SORT:
=SORT(A2:B10, 1, TRUE, 2, FALSE)
A2:B10
: Range to sort.1
: First sort column (fruit names).TRUE
: Sort in ascending order.2
: Second sort column (quantities).FALSE
: Sort in descending order.
data:image/s3,"s3://crabby-images/86346/86346fb22a1fc59f12de938db9497404259ec12e" alt="Sorting Data in a Range in Google Sheets: Example of Sorting Fruit Names and Quantities"
Ref.: Google Sheets SORT Function: Usage and Examples
Using SORTN:
=SORTN(A2:B10, 9, 0, 1, TRUE, 2, FALSE)
9
Specifies the number of rows to return after sorting.0
Represents thedisplay_ties_mode
for standard sorting (similar to SORT). Other modes can handle duplicates differently.1
and2
are the sort columns.TRUE
andFALSE
set the sort orders.
When compared to the SORT function, this formula includes two additional arguments: the number of rows to return and the display ties mode.
Ref.: How to Use the SORTN Function in Google Sheets
Using QUERY:
=QUERY(A2:B10, "WHERE Col1 IS NOT NULL ORDER BY Col1 ASC, Col2 DESC", 0)
Col1
(first column) is sorted inASC
(ascending) order.Col2
(second column) is sorted inDESC
(descending) order.- The
WHERE Col1 IS NOT NULL
condition filters out empty rows.
To retain the header row, use:
=QUERY(A1:B10, "WHERE Col1 IS NOT NULL ORDER BY Col1 ASC, Col2 DESC", 1)
data:image/s3,"s3://crabby-images/8bfa5/8bfa539bb3052ff76152edb6fa42974ee5fe43c6" alt="Retain the Header Row While Sorting in Google Sheets"
Ref.: Learn Google Sheets QUERY Function: Step-by-Step Guide
Sorting Data in Two Distant Columns
If your data is in distant columns (e.g., A2:A10 contains fruit names and C2:C10 contains quantities), use HSTACK to combine them horizontally before sorting.
Using SORT:
=SORT(HSTACK(A2:A10, C2:C10), 1, TRUE, 2, FALSE)
data:image/s3,"s3://crabby-images/4f7a3/4f7a3d74a32a2ee31981e0dc254b933fb38e472a" alt="Example of sorting data in two distant columns"
SORTN and QUERY Alternatives:
=SORTN(HSTACK(A2:A10, C2:C10), 9, 0, 1, TRUE, 2, FALSE)
=QUERY(HSTACK(A2:A10, C2:C10), "WHERE Col1 IS NOT NULL ORDER BY Col1 ASC, Col2 DESC", 0)
Sorting Data Based on a Column Outside the Sort Range
To sort a range based on a column outside the sort range (e.g., sorting weekday names in A2:A8 based on weekday numbers in C2:C8), use:
=SORT(A2:A8, C2:C8, TRUE)
data:image/s3,"s3://crabby-images/fa042/fa0426eaa1760980fcf6f738c22425430297b9ec" alt="Sorting a column using the 'SORTBY' parameter in SORT and SORTN functions"
Here is the SORTN Alternative:
=SORTN(A2:A8, 7, 0, C2:C8, TRUE)
When using QUERY, append the sort column horizontally and use the SELECT clause to exclude it from the final output.
=QUERY(HSTACK(A2:A8, C2:C8), "SELECT Col1 WHERE Col1 IS NOT NULL ORDER BY Col2 ASC", 0)
Sorting Data Using Structured Table References
A major benefit of structured table references is that they adjust dynamically when the table expands. Assume your table is named “Table1” with two columns: Item and Qty.
data:image/s3,"s3://crabby-images/72720/72720b2c67b781ab7b96b100392a49e6de0ed6df" alt="Sample data in a structured table format"
Formulas for Sorting Using Structured Table References:
=SORT(Table1, 1, TRUE, 2, FALSE)
=SORTN(Table1, 9, 0, 1, TRUE, 2, FALSE)
=QUERY(Table1, "WHERE Col1 IS NOT NULL ORDER BY Col1 ASC, Col2 DESC", 0)
To retain headers:
=QUERY(Table1[#ALL], "WHERE Col1 IS NOT NULL ORDER BY Col1 ASC, Col2 DESC", 1)
Is There a Function That Does the Opposite of Sorting?
While there’s no direct function to reverse sorting, you can randomize data using SORT and RANDARRAY:
=SORT(A2:B10, RANDARRAY(ROWS(A2:B10)), TRUE)
To keep the randomized order, copy the result and paste as values:
- Edit > Copy > Edit > Paste Special > Values Only
Google Sheets also has a Data > Randomize range menu option for this purpose.
Conclusion
This tutorial covered how to sort data in Google Sheets using SORT, QUERY, and SORTN, along with methods for handling structured tables and sorting non-adjacent columns. Mastering these functions will help you efficiently organize and analyze your data.
Resources
Explore these additional guides to master sorting in Google Sheets:
- Sort by Custom Order in Google Sheets
- Sort by Month Name in Google Sheets
- Sort Horizontally (Left to Right) in Google Sheets
- Custom Sort Order in Google Sheets Query
- Sort Alphanumeric Values in Google Sheets
- Sort by Date of Birth in Google Sheets
- Sort by Number of Occurrences in Google Sheets
- Sort Merged Cells in Google Sheets
- Row-Wise Sorting in a 2D Array
- Custom Sort by Partial Match in Google Sheets
Sort and “Order by” yield different results when using non-alphanumerics. e.g.,
{!,@,#,$,%,^,&,*,(,)}
is sorted differently by SORT and QUERY. SORT yields:{!,(,),{,},@,*,&,#,%,^,$}
while QUERY order by yields:{!,#,$,%,&,(,),*,@,^,{,}}
Why is this?
Hi, David Miller,
I’m not an expert to comment on this 🙁
Based on my understanding, QUERY() SORT BY sort order, ascending or descending, is based on ASCII code order.
On the other hand, the SORT() ascending order is as per numbers > special characters (custom order) > alphabets.
In descending order, it’s by alphabets > special characters (custom order) > numbers.
Hello! How do I sort Morning, Afternoon, and Evening chronologically? Please help.
Hi, Ems,
I can try to solve it. Can you leave below the URL of your sample sheet? I won’t publish it.
Hi Prashanth, I’m having a problem trying to order alphanumeric data like;
1 A
2 B
3 C
…
10 D
11 E
The result is 1 A, 10 D, 11 E, 2 B, 3 C
Hi, Frank,
I already have a tutorial on this – How to Properly Sort Alphanumeric Values in Google Sheets.
I couldn’t make it to work, but I did manage to kinda solve it by adding a zero before the number until 10.
Thank you anyway, you’re really helpful!
Hi, Frank,
Here is the Sort formula that I was talking about.
Assume the said strings to sorts are in C2:C, then to sort that list correctly, use the below formula in cell D2.
=sort(C2:C,VALUE(regexextract(C2:C,"(\d+)")),1)
The Regexextract extracts the numbers and sorts C2:C based on those extracted numbers.
Your method is best if you want the SORT menu command to use.
Cool. I’ve just discovered the SORT, FILTER, and QUERY functions thanks to your posts, and it’s so eye-opening.
I have one question though: What’s the use of the sort and filter menu when we’ve already have these functions?
I think the former is beginner-friendly, but it’s static, and if I understand it correctly, you would have to reselect the range of cells to sort and filter again when you add new data. Your thoughts?
Hi, Trang.
The formula is for sorting/filtering the data in a new range. On the other hand, the corresponding menu commands are for doing the same in the same range.
Formulas will include newly added rows/columns if you use an open range (eg. A1:C [open range], not A1:C10 [closed range]). But the menu won’t. That you need to repeat each time after making any changes to your data.