Using Wildcard for Folder Copy

huskersippi

New Member
Joined
Feb 10, 2017
Messages
7
I am able to copy all files from one subfolder but need to loop through directory and copy files from all subfolders with the same name.

Currently my folder structure is as such: C:\Users\Me\Desktop\TestLoop\Test-277\O&M\CopyFinal

So in this instance I would copy all .doc files from the CopyFinal subfolder. The issue is different names among the folder tree. The folder "Test-277" would be the name to change in the directory.

For example:

C:\Users\Me\Desktop\TestLoop\Test-277\O&M\CopyFinal
C:\Users\Me\Desktop\TestLoop\Test-278\O&M\CopyFinal
C:\Users\Me\Desktop\TestLoop\Test-279\O&M\CopyFinal

How can I use a wildcard value "Test-*" to allow my script to loop through entire directory and if there is a folder named CopyFinal, copy all files?

Here is my attempt so far:

Code:
Sub Copy_Folder()'This example copy all files and subfolders from FromPath to ToPath.
'Note: If ToPath already exist it will overwrite existing files in this folder
'if ToPath not exist it will be made for you.
    Dim FSO As Object
    Dim FromPath As String
    Dim ToPath As String


    FromPath = "C:\Users\Me\Desktop\TestLoop\Test-277\O&M\CopyFinal"  '<< Change
    ToPath = "C:\Users\Me\Desktop\Destination"    '<< Change


    'If you want to create a backup of your folder every time you run this macro
    'you can create a unique folder with a Date/Time stamp.
    'ToPath = "C:\Users\Me\Desktop\Destination" & Format(Now, "yyyy-mm-dd h-mm-ss")


    If Right(FromPath, 1) = "\" Then
        FromPath = Left(FromPath, Len(FromPath) - 1)
    End If


    If Right(ToPath, 1) = "\" Then
        ToPath = Left(ToPath, Len(ToPath) - 1)
    End If


    Set FSO = CreateObject("scripting.filesystemobject")


    If FSO.FolderExists(FromPath) = False Then
        MsgBox FromPath & " doesn't exist"
        Exit Sub
    End If


    FSO.CopyFolder Source:=FromPath, Destination:=ToPath
    MsgBox "You can find the files and subfolders from " & FromPath & " in " & ToPath


End Sub
 

Excel Facts

Convert text numbers to real numbers
Select a column containing text numbers. Press Alt+D E F to quickly convert text to numbers. Faster than "Convert to Number"
you need to first loop through every folder in "C:\Users\Me\Desktop\TestLoop" directory (instead of dictating Test - *). let's say you declare that as "FromPath", then you can say for each file in the FromPath & "\O&M\CopyFinal" copy to the ToPath. But based on the code you have above, i'm not sure if you are just moving entire folder into the ToPath or just the .doc files in the folder?
 
Upvote 0
Correct in the files im moving. It is the entire folder. I referenced .doc because those are the only files in these folders. How would I write that snipet "for each file in the FromPath & "\O&M\CopyFinal" copy to the ToPath"and where would I place it?
 
Upvote 0
Crazydragon84 Thank you for your help! I've solved. Below is the solution.


Code:
Sub cpy2Folders()
sourceF = "C:\SourceFolder\" 
destinationF = "C:\DestinationFolder\" 
Set FSO = CreateObject("Scripting.FileSystemObject") 
Set ofolder = FSO.GetFolder(sourceF) 
For Each subF In ofolder.subfolders 
    For Each sf In subF.subfolders 
        If InStr(UCase(sf), "TEST") > 0 Then 
            For Each testF In sf.subfolders 
                If InStr(UCase(testF), "FolderNameToSearchFor") > 0 Then
                    For Each shapeF In testF.Files 
                        FSO.copyfile shapeF, destinationF 
                    Next
                End If
            Next
        End If
    Next
Next
End Sub
 
Last edited:
Upvote 0

Forum statistics

Threads
1,224,825
Messages
6,181,191
Members
453,021
Latest member
pingpong7117

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