How to group rows in Excel to collapse and expand them

The tutorial shows how to group rows in Excel to make complicated spreadsheets easier to read. See how you can quickly hide rows within a certain group or collapse the entire outline to a particular level.

Worksheets with a lot of complex and detailed information are difficult to read and analyze. Luckily, Microsoft Excel provides an easy way to organize data in groups allowing you to collapse and expand rows with similar content to create more compact and understandable views.

Grouping rows in Excel

Grouping in Excel works best for structured worksheets that have column headings, no blank rows or columns, and a summary row (subtotal) for each subset of rows. With the data properly organized, use one of the following ways to group it.

How to group rows automatically (create an outline)

If your dataset contains just one level of information, the fastest way would be to let Excel group rows for you automatically. Here's how:

  1. Select any cell in one of the rows you want to group.
  2. Go to the Data tab > Outline group, click the arrow under Group, and select Auto Outline.

That's all there is to it!

Here is an example of what kind of rows Excel can group:
Use Excel's Auto Outline option to group rows automatically.

As shown in the screenshot below, the rows have been grouped perfectly and the outline bars representing different levels of data organization have been added to the left of column A.
The rows are grouped and the outline is created automatically.

Note. If your summary rows are located above a group of detail rows, before creating an outline, go to the Data tab > Outline group, click the Outline dialog box launcher, and clear the Summary rows below detail checkbox.

Summary rows below detail

Once the outline is created, you can quickly hide or show details within a certain group by clicking the minus Minus sign or plus Plus sign sign for that group. You can also collapse or expand all rows to a particular level by clicking on the level buttons Outline symbols in Excel in the top-left corner of the worksheet. For more information, please see How to collapse rows in Excel.

How to group rows manually

If your worksheet contains two or more levels of information, Excel's Auto Outline may not group your data correctly. In such a case, you can group rows manually by performing the steps below.

Note. When creating an outline manually, make sure your dataset does not contain any hidden rows, otherwise your data may be grouped incorrectly.

1. Create outer groups (level 1)

Select one of the larger subsets of data, including all of the intermediate summary rows and their detail rows.

In the dataset below, to group all data for row 9 (East Total), we select rows 2 through 8.
Select the rows you want to group.

On the Data tab, in the Outline group, click the Group button, select Rows, and click OK.
Group the rows manually.

This will add a bar on the left side of the worksheet that spans the selected rows:
An outer group is created.

In a similar manner, you create as many outer groups as necessary.

In this example, we need one more outer group for the North region. For this, we select rows 10 to 16, and click Data tab > Group button > Rows.

That set of rows is now grouped too:
An outline with two groups

Tip. To create a new group faster, press the Shift + Alt + Right Arrow shortcut instead of clicking the Group button on the ribbon.

2. Create nested groups (level 2)

To create a nested (or inner) group, select all detail rows above the related summary row, and click the Group button.

For example, to create the Apples group within the East region, select rows 2 and 3, and hit Group. To make the Oranges group, select rows 5 through 7, and press the Group button again.

Similarly, we create nested groups for the North regions, and get the following result:
Excel outline with nested groups

3. Add more grouping levels if necessary

In practice, datasets are seldom complete. If at some point more data is added to your worksheet, you will probably want to create more outline levels.

As an example, let's insert the Grand total row in our table, and then add the outermost outline level. To have it done, select all the rows except for the Grand Total row (rows 2 through 17), and click Data tab > Group button > Rows.

As shown in the screenshot below, our data is now grouped in 4 levels:

  • Level 1: Grand total
  • Level 2: Region totals
  • Level 3: Item subtotals
  • Level 4: Detail rows

An outline with 4 grouping levels

Now that we have an outline of rows, let's see how it makes our data easier to view.

How to collapse rows in Excel

One of the most useful features of Excel grouping is the ability to hide and show the detail rows for a particular group as well as to collapse or expand the entire outline to a certain level in a mouse click.

Collapse rows within a group

To collapse the rows in a particular group, just click the minus button Minus sign at the bottom of that group's bar.

For example, this is how you can quickly hide all detail rows for the East region, including subtotals, and show only the East Total row:
Click the minus button at the bottom of a group bar to collapse rows within a group.

Another way to collapse rows in Excel is to select any cell in the group and click the Hide Detail button on the Data tab, in the Outline group:
To collapse rows within a certain group, click the Hide Detail button.

Either way, the group will be minimized to the summary row, and all of the detail rows will be hidden.

Collapse or expand the entire outline to a specific level

To minimize or expand all the groups at a particular level, click the corresponding outline number at the top left corner of your worksheet.

Level 1 displays the least amount of data while the highest number expands all the rows. For example, if your outline has 3 levels, you click number 2 to hide the 3rd level (detail rows) while displaying the other two levels (summary rows).

In our sample dataset, we have 4 outline levels, which work this way:

  • Level 1 shows only Grand total (row 18 ) and hides all other rows.
  • Level 2 displays Grand total and Region subtotals (rows 9, 17 and 18).
  • Level 3 displays Grand total, Region and Item subtotals (rows 4, 8, 9, 18, 13, 16, 17 and 18).
  • Level 4 shows all the rows.

The following screenshot demonstrates the outline collapsed to level 3.
The outline collapsed to level 3.

How to expand rows in Excel

To expand the rows within a certain group, click any cell in the visible summary row, and then click the Show Detail button on the Data tab, in the Outline group:
Click the Show Detail button to expand the rows within a group.

Or click the plus sign Plus sign for the collapsed group of rows that you want to expand:
Click the plus sign for the group of rows you want to expand.

How to remove outline in Excel

In case you want to remove all row groups at once, then clear the outline. If you want to remove just some of the row groups (e.g. nested groups), then ungroup the selected rows.

How to remove the entire outline

Go to the Data tab > Outline group, click the arrow under Ungroup, and then click Clear Outline.
Removing outline in Excel

Notes:

  1. Removing outline in Excel does not delete any data.
  2. If you remove an outline with some collapsed rows, those rows might remain hidden after the outline is cleared. To display the rows, use any of the methods described in How to unhide rows in Excel.
  3. Once the outline is removed, you won't be able to get it back by clicking the Undo button or pressing the Undo shortcut (Ctrl + Z). You will have to recreate the outline from scratch.

How to ungroup a certain group of rows

To remove grouping for certain rows without deleting the whole outline, do the following:

  1. Select the rows you want to ungroup.
  2. Go to the Data tab > Outline group, and click the Ungroup button. Or press Shift + Alt + Left Arrow which is the Ungroup shortcut in Excel.
  3. In the Ungroup dialog box, select Rows and click OK.

For example, here's how you can ungroup two nested row groups (Apples Subtotal and Oranges Subtotal) while keeping the outer East Total group:
Ungrouping selected rows

Note. It is not possible to ungroup non-adjacent groups of rows at a time. You will have to repeat the above steps for each group individually.

Excel grouping tips

As you have just seen, it's pretty easy to group rows in Excel. Below you will find a few useful tricks that will make your work with groups even easier.

How to calculate group subtotals automatically

In all of the above examples, we have inserted our own subtotal rows with SUM formulas. To have subtotals calculated automatically, use the Subtotal command with the summary function of your choice such as SUM, COUNT, AVERAGE, MIN, MAX, etc. The Subtotal command will not only insert summary rows but also create an outline with collapsible and expandable rows, thus completing two tasks at once!

Apply default Excel styles to summary rows

Microsoft Excel has the predefined styles for two levels of summary rows: RowLevel_1 (bold) and RowLevel_2 (italic). You can apply these styles before or after grouping rows.

To automatically apply Excel styles to a new outline, go to the Data tab > Outline group, click the Outline dialog box launcher, and then select the Automatic styles check box, and click OK. After that you create an outline as usual.
Apply Automatic styles to summary rows.

To apply styles to an existing outline, you also select the Automatic styles box as shown above, but click the Apply Styles button instead of OK.

Here's how an Excel outline with the default styles for summary rows looks like:
An outline with the default styles for summary rows

How to select and copy only visible rows

After you've collapsed irrelevant rows, you may want to copy the displayed relevant data somewhere else. However, when you select the visible rows in the usual way using the mouse, you are actually selecting the hidden rows as well.

To select only the visible rows, you'll need to perform a few extra steps:

  1. Select visible rows using the mouse.

    For example, we have collapsed all of the detail rows, and now select the visible summary rows:
    Select the visible rows using the mouse.

  2. Head to the Home tab >Editing group, and click Find & Select > Go To Special. Or press Ctrl + G (Go To shortcut) and click the Special… button.
  3. In the Go To Special dialog box, select Visible cells only and click OK.
    Select Visible cells only and click OK.

As the result, only the visible rows are selected (the rows adjacent to hidden rows are marked with a white border):
Only the visible rows are selected.

And now, you simply press Ctrl + C to copy the selected rows and Ctrl + V to paste them wherever you like.

How to hide and show outline symbols

To hide or display the outline bars and level numbers in Excel, use the following keyboard shortcut: Ctrl + 8.

Pressing the shortcut for the first time hides the outline symbols, pressing it again redisplays the outline.

The outline symbols don't show up in Excel

If you can see neither the plus and minus symbols in the group bars nor the numbers at the top of the outline, check the following setting in your Excel:

  1. Go to the File tab > Options > Advanced category.
  2. Scroll down to the Display options for this worksheet section, select the worksheet of interest, and make sure the Show outline symbols if an outline is applied box is selected.

Show outline symbols if an outline is applied

This is how you group rows in Excel to collapse or expand certain sections of your dataset. In a similar fashion, you can group columns in your worksheets. I thank you for reading and hope to see you on our blog next week.

56 comments

  1. When the data is formatted as a table in excel I can group the rows, however, I can't adjust it so the summary row is above the detail.
    I appreciate one would ordinarily go to the Data tab > Outline group, click the Outline dialog box launcher, and then uncheck "Summary rows below detail", however, when the information is formatted as a table it wont let me click the Outline dialog box launcher.
    Has anyone else experienced this and do you know how to make the summary row above detail (without having to convert the data back to a range rather than a table)?
    Thanks

    • I have exactly the same issue. No summary rows, but a change in data type wants me to have summaries created above.

      Cannot find help anywhere.

  2. Hi, this should be a really easy question and I am embarrassed I cannot figure it out. I have 10 rows. All I want to do is create a grouping for the first 5 rows (row 1-5) and then create another grouping for the second set of 5 rows (row 6-10). I create the first grouping and it works fine. But when I select the rows 6-10 and click group, Excel combines all 10 rows into one group. Now there is only one group, and it either shows all 10 rows or nothing. But I want to be able to show either the first 5 rows or the last 5 rows. How do I accomplish that? Why does Excel combine all rows into one group even though I am selecting different rows (no overlap between the rows)?

  3. below is my text string in Cell A1 & A2 we need to find the text "IN" in same cell two different place at a time & extract number showing before that text e. g. 193 & 62 (left side of text ) using if error formula.
    TX01 INR 193IN TX02 INR 428K3 TX03 INR 236P2
    TX01 INR 160YR TX02 INR 180YR TX03 INR 62IN

      • provide us for excel formulas below is not working.
        =REPLACE(RegExpExtract(A1, "(\d+)IN"),LEN(RegExpExtract(A1, "(\d+)IN"))-1,2,"")

        • Dear Sir/Madam,
          Below is my two text string in different formats, we need to find text "IN" only in mentioned strings and extract the number showing before that text e.g. 531 or 413 "IN" text place is not fix in string its randomly change any place using IFERROR formula if not found then return should be zero.
          assuming below string in cell A1 and answer required in B2 = 531 or 413
          INR 80-YR XT INR 531-IN INR 1835-K3 INR 236-P2
          XT INR 413-IN INR 280-K3 INR 236-P2

          • Hi! Have you read the manual that was recommended to you? Add "-" to the formula

            =REPLACE(RegExpExtract(A1, "(\d+)-IN"),LEN(RegExpExtract(A1, "(\d+)-IN"))-1,2,"")

  4. Hi…
    I have a tool that produces a report listing files on a UNC path not accessed for some time, report can be 1000’s of lines

    Eg 1 Row

    \\server.com\sharename\folder1\folder2\spreadsheet. xlsx

    What id like to do is automatically group the report at each folder level

    The output from Treesize does this, but I don’t know how to do it from scratch in Excel

  5. Hello, pls help me find a way to do this method of grouping....

    in which we can expand or collapse data just like a drop down list, but instead of choosing a sigle data from dropdown list, i will be able to expand that cell with all the rows of data it hides.

    i.e
    similar to grouping but instead of the "+" and "-" symbols being shown outside the cells (in the left margin) in case of grouping, here the symbols will be on the cell itself which acts as a heading to the group of rows or data it contains or hides. so that when we press the "+" symbol it expands and "-" symbol it hides the data below just like when grouped.

    A difference i wish to see by doing so (when compared to grouping) being that, i can filter the cells by hiding the inside contents and after filtering or sorting, i can expand without any loss of data within each such cells.

  6. Hello! I'm trying to figure out how to group rows, but so that when filtering, Excel considers the grouped rows together and just uses the first data point in the group as the filter reference.

    Does this make sense?

    • Did you ever figure this out? I'm trying to do the same thing.

      • Same question: once rows are grouped, I would then like to apply filters but keep the grouped rows together

  7. Hi,
    Thanks for the tips.
    I'm using outline group and I'm trying to print just the active pages, but the hides one is print as blank. For example the sheets as 3 pgs when I use group reduce to 2 pgs, but it will print 3 with a blank pg in the middle.
    Is there a simple way of getting that?
    I know I could manually select the cells and print select area, but a lot of people use the file and I would like to be ready to go.
    thank you advance

    • It is explained in the head of:
      "How to select and copy only visible rows"

      After following it, select all and paste in another Sheet of Excel. Print that sheet blank will be avoided

  8. where can i get the sample dataset for practice.

  9. Hi!
    This was very helpful and easy to understand. I have seen it used before, but I didn't have a need for it myself until recently.

    Side note:
    I read some of the comments. My best advice for anyone with formatting or analysis questions is to start using Tables and Power Query. I held out on PQ for so long thinking the learning curve was too high and it wouldn't be useful for my needs. I'm still just getting started and I can already admit I was wrong.

    Now I just need to convince my coworkers to stop sending me .xls files...

  10. It's 2022 and I'm still finding this site - and this page in particular - super useful. Thank you!

  11. I have an excel database of approximately 204,000, with about 15,000 different names. Each name is repeated identically multiple times, depending upon how long they were current (in alphabetical order).

    I would like each name under the heading 'student ID' to be regarded as a separate group, and tell it to select the “last row in each student id group”. The aim being to end up with just one record for each of the approximately 15,000 students.

    Is this possible, and if so how do I achieve it?

    • Hi!
      I don't really understand what you want to do. This article explains how to group rows in Excel. If you didn't find the information you wanted, please describe the problem in more detail.

  12. I am building a spreadsheet that functions like a gantt chart (manually), so there are no calculations. I would like to show the client, project, and deadline on one row (I'll call it the header row). Below that, I would like to list tasks and corresponding start/end dates for that project. This will continue with various clients and projects.

    So, I would like to know if there is a way to group the header row and all subsequent task rows so that I can keep them together when sorting? For example, I may want to sort by client, project, or deadline (based on the header row) and be sure that all task rows stay grouped with the header row.

    If this is possible, is there also a way to collapse the task rows or hide them from view?

  13. How can I post a EXCEL sheet as an example to ask the question to you and get solution from you.
    I am using cut and paste below to send you sheet in case I can not attach the sheet. I want to add numbers in a column & show addition in the row next to last row in the column.
    Thanking you. RAKESH

    98,000.00 98,000.00 1,33,298.00 2,70,000.00 2,70,000.00 2,70,000.00

    3,50,000.00 3,50,000.00 4,76,065.00 2,14,000.00 2,14,000.00 2,14,000.00

  14. Hi , when I create a Create nested groups (level 2) it ungroup my last sub group is so annoying . Why ?

  15. We have a gsheet that is shared with three colleagues. They could not collapse grouped ones. Is there a way to give them access to it too?

  16. Awesome. Its really helpful

  17. Hi,
    I would like to auto/update grouped rows in pivot table when rows are added/removed from the data source rather than manually regrouping. Could anyone help with this?
    Thanks in advance.

  18. Hi!

    I want to create a PR plan and use grouping for activities related to the same main activity, but run to problems. I want to group 2-10 rows leaving the first row visible to mark the main activiti.

    For example my activity item is an article published on my website and have 5 items related to it. Now if I group all of these 6 rows, they all collide and hide. I can leave the first row ungrouped, but that wouldn't be the point of grouping.

    And if I have only 2 activites, then it wouldn't make any sense to group 1 row and leave one row visible.

    So long story short: how can I group rows in a way that would leave the first row visible?

  19. Is there a way to move the (+) symbol in line with the row the subset of data corresponds to? Excel is automatically placing the symbol one row down.

    • Alt, A, L; This opens the settings menu. Then make sure to uncheck the "Summary rows before detail" box.

  20. Hi - This is useful but does not help with my much simpler problem. I will use a simple example to explain my problem

    Column A is School
    Column B is Student

    So there will be multiple occurrences of the same School value on consecutive rows for each student

    I would like to be able to group by School automatically so as to be able to expand/collapse School to reveal and collapse to show all students. I have no wish to sum anything, this is purely to make the sheet manageable

    Any ideas - this seems like it should be simple

  21. Really, it is very useful.

  22. I have a sorted column and want to create a group whenever the value value in the column changes. I get a 'Cannot create an outline' error message. There are hundreds of value changes. Is there a size limit to this feature.

    Thanks

  23. Hello!

    My outline symbols are not visible. The box is checked in advanced and I tried the ctrl + 8 and nothing is working! Please advise!

  24. How does this work if there is no arrow in low right corner?
    How can I open that sub menu?

  25. Thank you for the Outline Symbols Don't Show Up fix. I had 1 workbook with 5 sheets... and they would not show the group row symbols. If I clicked on "Show Detail" or "Hide Detail" in Outline Menu it would group, but with no way to see multi level groupings. I created 5 NEW sheets (same workbook) and copied the data and the new worksheets would show the group symbols. So question is, did I accidentally do a keyboard combination that "turned off" (or unchecked) the Show Symbol in the Advance Options? Just hoping to prevent that from occurring again.

  26. Hi Folks,

    When I unchecked the View under Headings in the Page Layout tab the Level Buttons disappears.
    Is there a way to move or relocate the Level Buttons anchored to top level corner or have the Level Buttons not disappear?
    Any help would be greatly appreciated! Thank you!

  27. How to group in Excel

  28. Is there a shortcut to hide the rows after using Shift-Alt-Right arrow to group them?

    • Hi Jeff,

      You can use the Ctrl + 9 shortcut to hide rows and Ctrl + Shift + 9 to unhide.

  29. Is there any way to make a group, which contains all the rows in a table, extend by one row everytime you add a row to the table?

  30. Hi and thanks for the detailed information. My query is rather simple, but cant find how to do it.

    I have 90 groups of 11 rows, the first row of each 11 rows is a heading and I have laid them out alphabetically. How can I add another group of 11 rows between two sets of groups WITHOUT creating another level of grouping?

  31. How to hide ribbons only for one sheet in a workbook?
    need help please

    • Mohammed:
      The only way I know to hide the ribbons or formula bars for one worksheet is by using some VBA code.
      There are various approaches to accomplishing this. You can find them by searching Google with Hide Ribbons in Excel.

  32. Hi! Thanks for the information. I do have a special question:

    Let's asume I have grouped rows from 10 to 15. Now I insert a new blank line above line 10 (e.g. above row 2). Grouping now remains in rows 10 to 15, but I want to have it shifted one row down to 11 to 16 (as the data is there). Is there any chance to "attach" the grouping to data instead of row-numbers?

    • Sorry, I need to add the information, that I formatted row 1 to 8 as a table! If I add a row in this table, then the grouping remains on row 10 to 15. If I do not format row 1 to 8 as table, grouping shifts one row down if a blank row is inserted

  33. Hi
    Awesome information, thanks
    I have a question, Is there a way to name the groups?
    I would like to see if this can be posible

    thanks

  34. Hi,
    My data group function isn't working on one page in a workbook....works fine on the others.
    Any ideas how to fix it?
    Thanks, Becky

  35. Hello,

    Is there a way to record/write a macro that hides/unhide specific grouped rows? I want to be able to further customize the data that is being viewed by the user. - Simply writing VBA code that hides/unhides specific rows/columns within the worksheet does not seem to work when the data is outlined/grouped.

    Thanks!

  36. Dear,
    I want to copy different cell and rows and paste in another sheet as group data by excel vb. Thanks in advance.

  37. Hi there,

    Thanks so much for this, it is super helpful! I have followed this and have grouped rows under certain categories and it is clean and easy to follow. However, I created a Pivot Table and this does not seem to recognize the grouped rows in the data set. More specifically, I have listed item names (which is the pivot table filter) at the top of each of the grouped rows but it does not repeat within the rows - so the pivot table isn't reading the below rows as being within the filter item resulting in the pivot table not working. Is there a quick fix to this? Or do I need to put the filter item in every row within the groups in the data set? Thanks in advance for your help.

    • Hello,
      For me to understand the problem better, please send me a small sample workbook with your source data and the result you expect to get to support@ablebits.com. Please don't worry if you have confidential information there, we never disclose the data we get from our customers and delete it as soon as the problem is resolved.
      Please also don't forget to include the link to this comment into your email.
      I'll look into your task and try to help.

Post a comment



Thank you for your comment!
When posting a question, please be very clear and concise. This will help us provide a quick and relevant solution to
your query. We cannot guarantee that we will answer every question, but we'll do our best :)