Batch File To Copy Pictures

I am looking for a way to copy all of my digital camera pictures into a folder by using a batch file.  If it's possible, I would like the batch file to read the date that the picture was taken, and make that date the name of the folder.  Once the folder is created, I need the batch to copy all photos to the folder that corresponds to the date the picture was taken . Is this a fairly simple process? Can someone provide a sample of how I would do this, or point me in the right direction? Thanks.
thedeal56Asked:
Who is Participating?
I wear a lot of hats...

"The solutions and answers provided on Experts Exchange have been extremely helpful to me over the last few years. I wear a lot of hats - Developer, Database Administrator, Help Desk, etc., so I know a lot of things but not a lot about one thing. Experts Exchange gives me answers from people who do know a lot about one thing, in a easy to use platform." -Todd S.

Shift-3Commented:
This is beyond the capabilities of batch scripting, but could probably be done with vbscript.  Like batch, vbscript runs natively without installing any additional software.  Would that be acceptable?

Also, I don't have a digital camera to test with, but when you connect yours does it show up in the Storage\Disk Management node in Computer Management?  Can you right-click it , hit Change Drive Letter and Paths, click Add, and mount it to an empty NTFS folder on your C: drive?

If so then moving the files from a mounted folder would be a lot easier than trying to grab them directly from the camera.
0
Shift-3Commented:
Assuming all those things are true, paste the script below into a text file with a .vbs extension.  Customize the value of the strSource variable on line 1 with the location of the folder you mounted the camera to.  Customize the value of the strDest variable with the location of the folder to move the photos to.

Running the script will move all pictures from the camera to subfolders named for the dates they were taken.


strSource = "c:\camera mount point"
strDest = "c:\photos"
 
Set objWMIService = GetObject("winmgmts:\\.\root\cimv2")
Set colItems = objWMIService.ExecQuery("Select * From Win32_OperatingSystem")
 
For Each objItem in colItems
    If InStr(objItem.Caption, "Vista") Or InStr(objItem.Caption, "2008") Then
        intDetail = 12
    Else
        intDetail = 25
    End If
Next
 
Set objFSO = CreateObject("Scripting.FileSystemObject")
 
If Not objFSO.FolderExists(strDest) Then
    objFSO.CreateFolder strDest
End If
 
Set objShell = CreateObject("Shell.Application")
Set objSource = objShell.Namespace(strSource)
 
For Each objFile in objSource.Items
    dtmTaken = objSource.GetDetailsOf(objFile, intDetail)
    
    If dtmTaken <> "" Then
        strNewFolder = strDest & "\" & ShortDate(dtmTaken)
        
        If Not objFSO.FolderExists(strNewFolder) Then
            objFSO.CreateFolder strNewFolder
        End If
 
        objFSO.MoveFile objFile.Path, strNewFolder & "\"
    End If
Next
 
Function ShortDate(dtmTime)
    strYear = Year(dtmTime)
    strMonth = Right("0" & Month(dtmTime), 2)
    strDay = Right("0" & Day(dtmTime), 2)
    
    ShortDate = strYear & strMonth & strDay
End Function

Open in new window

0

Experts Exchange Solution brought to you by

Your issues matter to us.

Facing a tech roadblock? Get the help and guidance you need from experienced professionals who care. Ask your question anytime, anywhere, with no hassle.

Start your 7-day free trial
thedeal56Author Commented:
Wow, thank you very much.  That is very cool; it works great.
0
It's more than this solution.Get answers and train to solve all your tech problems - anytime, anywhere.Try it for free Edge Out The Competitionfor your dream job with proven skills and certifications.Get started today Stand Outas the employee with proven skills.Start learning today for free Move Your Career Forwardwith certification training in the latest technologies.Start your trial today
Windows Batch

From novice to tech pro — start learning today.