List Files In Subfolders with Modified Date

blimbert

New Member
Joined
Jan 25, 2005
Messages
21
Hello - I am trying to obtain a file listing of all files in a network folder, and multiple layers of subfolders.

Requirements:
  1. Return filename, file path, file type, and file last modified date to an excel sheet
  2. Evaluate all files within all subfolders. In other words if there are nested subfolders, evaluate the files within every subfolder and its subfolders
  3. Obtain the file information if the last modified date is after a certain date (eg >=1/1/2022)
  4. Obtain the file information if the file type is a certain file type (eg .xlsx)
I have tried various code snippets from various sources and have not yet found one that works as desired.

Could you please help?
 
Sorry. This is an old code. I don't remember exactly what each line does. You may have to debug
 
Upvote 0

Excel Facts

Workdays for a market open Mon, Wed, Friday?
Yes! Use "0101011" for the weekend argument in NETWORKDAYS.INTL or WORKDAY.INTL. The 7 digits start on Monday. 1 means it is a weekend.
Here a recursive approach

VBA Code:
Dim xp, ar, x As Long

Sub jec()
  ReDim ar(3, 0)
  xp = "": x = 0
  M_getFile "C:\Users\xxx\Downloads\"   ' -->  change path to suit
  Range("A1").Resize(x, 4) = Application.Transpose(ar)
End Sub

Sub M_getFile(xp)
 Dim it, itl
 With CreateObject("scripting.filesystemobject").GetFolder(xp)
   For Each it In .Files
     If it.DateLastModified >= DateSerial(2022, 1, 1) And it.Name Like "*.xlsx" Then
       ReDim Preserve ar(3, x)
       ar(0, x) = it.Name
       ar(1, x) = it.Path
       ar(2, x) = it.Type
       ar(3, x) = it.DateLastModified
       x = x + 1
     End If
   Next
   For Each it1 In .SubFolders
     M_getFile it1.Path
   Next
 End With
End Sub
 
Upvote 2
My solution is a complete change in tack, but knowing what i now know about Powerquery there is no way I would use VBA to collect directory information. Follow the steps below and you will return a list of all files with the information you're after. You can remain in the Powerquery editor to filter on whatever parameters you need and potentially combine the files into a single data source:

1. Open the Data ribbon.
2. Click on little down arrow by the 'Get Data' and select 'From File' then 'From Folder'.
3. Navigate to the top of the folder structure of interest and click 'OK'.
4. In the dialogue box that appears select Transform Data.
5. You will now be in the Powerquery Editor.
6. On the Home ribbon select 'Close & Load'.

You will then have a table in excel that contains all files in the folder structure together with their Path, File Extension, Date/Time Accessed, Date/Time Modified, and Date/Time Created.

There is so much you can do with Powerquery and PowerPivot that getting to grips with them should be a key part of an excel users repertoire (in my opinion :)).
HTH.
 
Upvote 1
Here a recursive approach

VBA Code:
Dim xp, ar, x As Long

Sub jec()
  ReDim ar(3, 0)
  xp = "": x = 0
  M_getFile "C:\Users\xxx\Downloads\"   ' -->  change path to suit
  Range("A1").Resize(x, 4) = Application.Transpose(ar)
End Sub

Sub M_getFile(xp)
 Dim it, itl
 With CreateObject("scripting.filesystemobject").GetFolder(xp)
   For Each it In .Files
     If it.DateLastModified >= DateSerial(2022, 1, 1) And it.Name Like "*.xlsx" Then
       ReDim Preserve ar(3, x)
       ar(0, x) = it.Name
       ar(1, x) = it.Path
       ar(2, x) = it.Type
       ar(3, x) = it.DateLastModified
       x = x + 1
     End If
   Next
   For Each it1 In .SubFolders
     M_getFile it1.Path
   Next
 End With
End Sub

Hi JEC
This is perfect.
Thank you very much.
 
Upvote 0
My solution is a complete change in tack, but knowing what i now know about Powerquery there is no way I would use VBA to collect directory information. Follow the steps below and you will return a list of all files with the information you're after. You can remain in the Powerquery editor to filter on whatever parameters you need and potentially combine the files into a single data source:

1. Open the Data ribbon.
2. Click on little down arrow by the 'Get Data' and select 'From File' then 'From Folder'.
3. Navigate to the top of the folder structure of interest and click 'OK'.
4. In the dialogue box that appears select Transform Data.
5. You will now be in the Powerquery Editor.
6. On the Home ribbon select 'Close & Load'.

You will then have a table in excel that contains all files in the folder structure together with their Path, File Extension, Date/Time Accessed, Date/Time Modified, and Date/Time Created.

There is so much you can do with Powerquery and PowerPivot that getting to grips with them should be a key part of an excel users repertoire (in my opinion :)).
HTH.

Hi pjmorris,

This is doing the same job as VBA just need to follow few steps.

a BIG Thank you.
 
Upvote 0
Here a recursive approach

VBA Code:
Dim xp, ar, x As Long

Sub jec()
  ReDim ar(3, 0)
  xp = "": x = 0
  M_getFile "C:\Users\xxx\Downloads\"   ' -->  change path to suit
  Range("A1").Resize(x, 4) = Application.Transpose(ar)
End Sub

Sub M_getFile(xp)
 Dim it, itl
 With CreateObject("scripting.filesystemobject").GetFolder(xp)
   For Each it In .Files
     If it.DateLastModified >= DateSerial(2022, 1, 1) And it.Name Like "*.xlsx" Then
       ReDim Preserve ar(3, x)
       ar(0, x) = it.Name
       ar(1, x) = it.Path
       ar(2, x) = it.Type
       ar(3, x) = it.DateLastModified
       x = x + 1
     End If
   Next
   For Each it1 In .SubFolders
     M_getFile it1.Path
   Next
 End With
End Sub

Hi JEC
While working with thousands of files in a folder of subfolders, it is taking too much time.
is there any way to make it faster?
 
Upvote 0
Looping through thousands of files with these conditions, is never going to be super fast. If you need to do this once in a while the durations would not be an issue right? How long does it take?

Note: having thousands of items, applications transpose will probably fail. I suggest you ReDim the array big enough. Then you do not need transpose
 
Upvote 0
If you need to do this once in a while the durations would not be an issue right?
Right.

How long does it take?
My friend didn't wait much, he just went to task manager and ended the task.
I think it will take a few minutes, but no problem we can wait for a few minutes.

Note: having thousands of items, applications transpose will probably fail. I suggest you ReDim the array big enough. Then you do not need transpose
As I know nothing about VBA, I don't understand what you are trying to say.
 
Upvote 0

Forum statistics

Threads
1,225,481
Messages
6,185,233
Members
453,283
Latest member
Shortm88

We've detected that you are using an adblocker.

We have a great community of people providing Excel help here, but the hosting costs are enormous. You can help keep this site running by allowing ads on MrExcel.com.
Allow Ads at MrExcel

Which adblocker are you using?

Disable AdBlock

Follow these easy steps to disable AdBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the icon in the browser’s toolbar.
2)Click on the "Pause on this site" option.
Go back

Disable AdBlock Plus

Follow these easy steps to disable AdBlock Plus

1)Click on the icon in the browser’s toolbar.
2)Click on the toggle to disable it for "mrexcel.com".
Go back

Disable uBlock Origin

Follow these easy steps to disable uBlock Origin

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back

Disable uBlock

Follow these easy steps to disable uBlock

1)Click on the icon in the browser’s toolbar.
2)Click on the "Power" button.
3)Click on the "Refresh" button.
Go back
Back
Top