Getting Started with the Excel FILES Function
The FILES function is a legacy Excel 4 Macro function that lists all files contained within a specified folder.
Though not available in the conventional Excel functions list, you can still use it if you know how to enable it.
Setting Up the FILES Function
To demonstrate, let's create a list of files in a folder on my C:\ drive.
Note: You need to add a backslash and an asterisk \* at the end of the folder path for the function to work, like so:
C:\temp\Demo\*
To enable the FILES Function:
Define the FILES Function as a Named Formula:
Go to the Formulas tab and click on Define Name:
data:image/s3,"s3://crabby-images/ea575/ea575a85aa660e98e6550d256b982b74fc8073f0" alt="Define Name"
Name it fileList
In the Refers to section, input the formula: =FILES(Sheet1!$C$3) where $C$3 contains your folder path.
data:image/s3,"s3://crabby-images/a9fab/a9fab9502c143320a49ca1c5a55945ad4a687943" alt="Refers to section"
Using the FILES Function in Excel:
In versions of Excel that support dynamic arrays, simply type =fileList to spill the results across multiple columns.
For a column list, wrap it in the TRANSPOSE function:
data:image/s3,"s3://crabby-images/7dce7/7dce76df90e1f8803c9dccd0b7ed60b478eee5e1" alt="TRANSPOSE Function"
If your Excel version doesn't support dynamic arrays, there are alternative methods available, which I'll discuss later.
Dynamic
Folder Path
To dynamically update the folder path based on the location of your file:
Use the CELL function with TEXTBEFORE to return the file path of the current file and concatenate it with an asterisk:
data:image/s3,"s3://crabby-images/48353/483534cb31b6de6be61adf28251dc09396af893b" alt="Dynamic Folder Path"
Note: If you're using an earlier Excel version that doesn't support TEXTBEFORE, use this formula:
=LEFT(CELL("filename",C1),FIND("[",CELL("filename",C1))-1)&"*"
Filtering File Types
To filter the list to specific file types, modify the path to include the file extension, for example: C:\temp\Demo\*.xlsx for Excel
files only.
For more dynamic filtering:
Create a dropdown list with common file types and an option to show all file
types.
data:image/s3,"s3://crabby-images/ff268/ff2686674a5e6d57cc730f703e26efcc3bd7dffe" alt="Dropdown List"
Use the IF function to check the file type selected in a cell (e.g. C5):
IF(C5="all files", "", C5)
Append this formula to the folder path with the ampersand for dynamic filtering.
data:image/s3,"s3://crabby-images/9deeb/9deeb1282afa439d587ad1172c8c7504ddb0d57c" alt="Dynamic Filtering"
Counting Files
To count the files in a folder, wrap the fileList formula in the COUNTA function:
=COUNTA(fileList)
data:image/s3,"s3://crabby-images/35f49/35f49dd7d410eae9e87fe90e531ccc7171862e54" alt="COUNTA"
Non-Dynamic Arrays Formula to List Files in a Folder
For users on Excel 2019 and earlier you can use the INDEX
function to extract file names and wrap it in the IFERROR function to allow copying it down more rows than you currently have files for in the folder. This will automatically list any new files added to the folder.
I'll define a new FILES formula for non-dynamic arrays (e.g. fileListNonDA):
data:image/s3,"s3://crabby-images/fbf5f/fbf5f04729b8f290469bfa54d18dff07c15acaa6" alt="Non-Dynamic Arrays Formula"
Extract File Names with INDEX and IFERROR:
=IFERROR(INDEX(fileListNonDA, ROW(A1)), "")
Copy the formula down to cover the expected number of files and allow for more files if required:
data:image/s3,"s3://crabby-images/6fb3b/6fb3b419827ad8e23c2efd1f0a61491a8914f1af" alt="Extract File Names"
Generating a Hyperlinked List of
Files
If you want to create a clickable list of file names that open the files directly from Excel, we can use the non-dynamic array technique above to extract the list of files in a folder and hyperlink them:
Create Hyperlinks
Modify the formula above to include the HYPERLINK function with the file path and file name as follows:
=IFERROR(HYPERLINK(LEFT($C$3, LEN($C$3)-1) & INDEX(fileListNonDA, ROW(A1)), INDEX(fileListNonDA, ROW(A1))), "")
Apply Conditional Formatting
The hyperlinks generated with a formula like this don't get automatically formatted in blue font with an underline, however we can use Conditional Formatting to do this for us.
Go to the Home tab > Conditional
Formatting > New Rule:
data:image/s3,"s3://crabby-images/f6849/f6849b9b339cbe8e8c4a8c962c94389ae6e96e3a" alt="Conditional Formatting"
Select the 'Use a formula to determine
which cells to format' and in the formula field type:
=$C6<>""
Then click the 'Format…' button:
data:image/s3,"s3://crabby-images/7ce49/7ce4999834187d949742d8468699a45bfee91f78" alt="Format Cells"
In the Format Cells dialog box apply a blue font and underline:
data:image/s3,"s3://crabby-images/23d3f/23d3f8069c867f89568afb2cb6a9177726b7eb7b" alt="Format Cells Dialog Box"
Enabling Macros
Since the FILES function is a macro, you need to save your file as .xlsm and enable XLM macros in Excel. Here's
how:
- Go to the File tab, click Options > Trust Center > Trust Center Settings.
- Under Macro Settings, select Enable Excel 4.0 macros when VBA macros are enabled:
- Adjust File Block Settings to allow opening Excel 4 Macrosheets in Protected
View:
data:image/s3,"s3://crabby-images/2f751/2f75190014183288adb290ebd1657a5d3cf454ba" alt="File Block Settings"
Using Power Query as an Alternative
For an alternate method that works in all versions of Excel and doesn't require
macros, use Power Query to list file names in a folder and sub-folders:
Import File Names with Power Query
Go to the Data tab > Get Data > From File > From Folder:
data:image/s3,"s3://crabby-images/60214/602147bafbe8852f7bcd3602267f0e9d7e594c4c" alt="Power Query Get Data"
Browse to your folder or paste the path.
data:image/s3,"s3://crabby-images/08d7f/08d7fd44270732d783cea5f5524c8b9365b1670d" alt="Paste the Path"
Transform and Load Data
In the Power Query editor, click on the double headed arrow on the Attributes column and select the attributes you want (e.g. file size):
data:image/s3,"s3://crabby-images/bcfdc/bcfdcd90c20ba6660222735c841a9664cb31a460" alt="Select the attribute"
Filter out any folders you don't want the file names for.
Rename the query, remove unnecessary columns, and load the data.
data:image/s3,"s3://crabby-images/8bd28/8bd287413203d793a15df2be0cd8e09bc9e7b547" alt="Filter Unwanted Folders"
Filter and Refresh
Filter
the list based on file extensions.
data:image/s3,"s3://crabby-images/f6d47/f6d4725310a0b26c35e39e0a21bd9debe6e27431" alt="Filter based on extensions"
Or insert a Slicer for easy
filtering and refresh to update the list with new files.
data:image/s3,"s3://crabby-images/a41e7/a41e7fe3cb9bc3308af28f5d9c34eae6886ebb56" alt="Refresh to update"
Choose the
field you want a Slicer for:
data:image/s3,"s3://crabby-images/32fce/32fce6cb39b351e0315b80c90bf8b50a653f7db0" alt="Select a field in the Slicer"
Select the file extension you
want to display in the list:
data:image/s3,"s3://crabby-images/00cef/00cef477ffc175cb1e515b09cd437dc46d93fc83" alt="Select the file extension"
Conclusion
The FILES function is a hidden gem in Excel,
offering a powerful way to manage file lists. Whether you use the legacy macro approach or Power Query, you now have the tools to list file names in a folder in Excel effectively.