How to Create Automatic Table of Contents for Sheets in Excel
data:image/s3,"s3://crabby-images/a3155/a31558de6593d9de4fa2dc6eef665b805581b260" alt=""
How to Create Automatic Table of Contents for Sheets in Excel. Sometimes, you may have to work with hundreds or even thousands of sheets in an Excel file. Are you tired of constantly moving between different sheets? Then you can’t miss today’s article. Let’s learn how to create an automatic table of contents for sheets in Excel.
Display the Developer create Automatic Table
Usually, the Developer tab will not be displayed by default, similar to other common tabs such as Home, Insert, etc. Therefore, to display this tab, right-click on the ribbon and select Customize the Ribbon.
data:image/s3,"s3://crabby-images/a23b2/a23b23243fdde6d3b0ac8d9dfa4e530278f3b15f" alt="How to Create Automatic Table of Contents for Sheets in Excel 1 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Then, the Excel Options dialog box will appear. Look to the right and you will see that the Developer option is not selected. Check that option and click OK. Now you will see the Developer tab at the top.
data:image/s3,"s3://crabby-images/13d9d/13d9d04d6f840cc07363337fc125227e244ae3c0" alt="How to Create Automatic Table of Contents for Sheets in Excel 2 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Get the Full Names of all Sheets
After displaying the Developer tab, we will start step by step to create an automatic table of contents for sheets in Excel. First, select Visual Basic on the Developer tab.
data:image/s3,"s3://crabby-images/8d542/8d542e77dc369fc4b6e7017957d7070c2eebeb47" alt="How to Create Automatic Table of Contents for Sheets in Excel 3 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Then, the Microsoft Visual Basic for Applications dialog box will appear. Right-click on the name of the first sheet in the Microsoft Excel Objects section, select Insert, and then select Module to create a new module. The purpose of this operation is to create a file to write code.
data:image/s3,"s3://crabby-images/13c27/13c278a91bff0f7606d8af7ff35fe6e2ab8aced4" alt="How to Create Automatic Table of Contents for Sheets in Excel 4 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Next, we will write the first code block to retrieve the index number and name of all the currently existing sheets. Please note that you should follow along with the video above to make it easier to follow the coding process. First, we declare the necessary variables: “wb” is an abbreviation for the main Workbook which is the Excel file that you are using, “ws” is an abbreviation for the current Worksheet that you are working on, “isheet” is a counter variable, and “irow” is a variable that stores the value of the row index of the cell. After declaring the necessary variables, we initialize with the two commands below.
data:image/s3,"s3://crabby-images/22c61/22c61bd10137477569547f8454f8da0c3e02d5b3" alt="How to Create Automatic Table of Contents for Sheets in Excel 5 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Once the variables have been declared and initialized, we will create a loop to iterate through all the sheets. This loop will run from 2 (which is assigned to the “isheet” variable) to the total number of sheets that you have. First, the index number is obtained by subtracting 1 from the “isheet” variable, and the name of the sheet is obtained by using the command “wb.Sheets(isheet).Name”. Finally, you increment “irow” by 1 so that the next iteration of the loop will apply the values to the next row below. After you have completed this, press the green arrow button above to run the code block. At this point, your sheet’s table of contents should display the index number and name of each sheet.
data:image/s3,"s3://crabby-images/1639e/1639eed25e103a64ba5595e36aa80f577de9ae1d" alt="How to Create Automatic Table of Contents for Sheets in Excel 6 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Example:
isheet = 2
irow = 6
For isheet = 2 To wb.Sheets.Count
ws.Range(“B” & irow).Value = isheet – 1
ws.Range(“C” & irow).Value = wb.Sheets(isheet).Name
Next
Create links to sheets
The next step is to create links to the sheets from the table of contents. You can enter the code snippet shown below. The first line will select the current worksheet, the next line will select the cell where you want to insert the link, and the last line will create a hyperlink to the sheet you specify with the text “go to sheet”. Once you’re done, click the green arrow button at the top to run the code.
data:image/s3,"s3://crabby-images/6bfae/6bfaebf2f55dba1b95762b960ab4c5fc7388e437" alt="How to Create Automatic Table of Contents for Sheets in Excel 7 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
Example:
ws.Select
ws.Range(“D” & irow).Select
ws.Hyperlinks.Add Anchor:=Selection, Address:=””, SubAddress:=”‘” & wb.Sheets(isheet).Name & “‘!A1″, TextToDisplay:=”go to sheet”
Create a button to go back to the table of contents from each sheet
After creating the links, you should create a button to go back to the table of contents on each sheet to avoid having to scroll through hundreds or thousands of sheets. You can create a block by selecting Shapes from the Insert tab and choosing any block, as the button means “go back,” I will choose an arrow-shaped block.
data:image/s3,"s3://crabby-images/95fdd/95fdd830e3ede6c5dfb8c786edf9e8aad386f058" alt="How to Create Automatic Table of Contents for Sheets in Excel 8 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
To enter content for the block you just created, right-click on the block, choose Edit Text, and enter the desired text. You can also adjust the size, color, and alignment of this content.
data:image/s3,"s3://crabby-images/3b4c0/3b4c038816a5338373c300fa7fb4fb7b9e2f1929" alt="How to Create Automatic Table of Contents for Sheets in Excel 9 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
The next step is quite important. You need to know the name of the block you just created because it will be necessary for the code we are about to execute. To see the name of the block, select it and look at the cell located in the upper left corner of the current sheet.
data:image/s3,"s3://crabby-images/63db0/63db0353955651d151c83e84c428b543059ab953" alt="How to Create Automatic Table of Contents for Sheets in Excel 10 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
To create a hyperlink for a block, first right-click on the block and select Link.
data:image/s3,"s3://crabby-images/141a9/141a919782875bec81c045fcb63d6944342afcff" alt="How to Create Automatic Table of Contents for Sheets in Excel 11 How to Create Automatic Table of Contents for Sheets in Excel"
How to Create Automatic Table of Contents for Sheets in Excel
At this point, the Insert Hyperlink dialog box will appear. Choose Place in This Document and then scroll up to select your table of contents sheet. Once done, click OK to create the hyperlink.
After following the steps above, you have created a button to return to the table of contents sheet, but it does not exist on other sheets yet. Therefore, we need to use an additional piece of code to create similar buttons on the remaining sheets. In the code below, the first line is to select the button that we created in the previous steps (which now has a hyperlink to the table of contents), the second line is to execute the copy command, the third line is to select the current sheet (based on the value of isheet in each loop), the fourth line is to select the cell, and the last line is to paste the button into the selected cell.
Once done, press the green arrow above to run the code. Good luck with your practice!