Solved

How to create a list with filename and "Date Picture Taken"

Posted on 2008-09-30
11
1,085 Views
Last Modified: 2012-06-27
Is there any simple method to export (create) a list with filename and "Date Picture Taken" within a directory?
0
Comment
Question by:Hoogendoorn
[X]
Welcome to Experts Exchange

Add your voice to the tech community where 5M+ people just like you are talking about what matters.

  • Help others & share knowledge
  • Earn cash & points
  • Learn & ask questions
  • 5
  • 5
11 Comments
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22606438
Something like this maybe?

Just save it as a VBS in the directory you want to scan.
Option Explicit
Dim fso, objShell, objFolder, tFolder, tFile
Dim currentFolder
Set fso=CreateObject("scripting.filesystemobject")
currentFolder = fso.GetAbsolutePathName(".")&"\"
Set tFolder = fso.getfolder(CurrentFolder)
Set objShell = CreateObject ("Shell.Application") 
Set objFolder = objShell.Namespace(Currentfolder) 
 
For each tFile in tFolder.files
If UCase(FileExt(tFile.name)) = "JPG" Then
     wscript.echo objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 0) 
     wscript.echo objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 10) 
     wscript.echo objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 24) 
     wscript.echo objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 25) 
 
'Extended file properties:
'0 Name 
'1 Size 
'2 Type 
'3 Date Modified 
'4 Date Created 
'5 Date Accessed 
'6 Attributes 
'7 Status 
'8 Owner 
'9 Author 
'10 Title 
'11 Subject 
'12 Category 
'13 Pages 
'14 Comments 
'15 Copyright 
'16 Artist 
'17 Album Title 
'18 Year 
'19 Track Number 
'20 Genre 
'21 Duration 
'22 Bit Rate 
'23 Protected 
'24 Camera Model 
'25 Date Picture Taken 
'26 Dimensions 
'27 
'28 
'29 Episode Name 
'30 Program Description 
'31 
'32 Audio sample size 
'33 Audio sample rate 
'34 Channels 
'35 Company 
'36 Description 
'37 File Version 
'38 Product Name 
'39 Product Version 
'40 Keywords 
End If
 
Next
 
Set fso=Nothing
Set tFolder = Nothing
Set tFile = Nothing
Set objFolder = Nothing
 
Function FileExt(FileName)
FileExt = Right(FileName, Len(FileName)-instrrev(FileName,"."))
End Function

Open in new window

0
 

Author Comment

by:Hoogendoorn
ID: 22607471
Thanks for your effort, Brandon. Unfortunately, I am an 'old' guy, only familiar with Fortran programming. Could you make to the script so, that it saves the file properties (including filename) to a file?
0
 
LVL 50

Expert Comment

by:jcimarron
ID: 22607615
Hoogendoorn--Possibly Karens Directory Printer
http://www.karenware.com/powertools/ptdirprn.asp
Very configurable.
0
Instantly Create Instructional Tutorials

Contextual Guidance at the moment of need helps your employees adopt to new software or processes instantly. Boost knowledge retention and employee engagement step-by-step with one easy solution.

 
LVL 39

Accepted Solution

by:
BrandonGalderisi earned 250 total points
ID: 22607839
This will output to a file called PictureInfo.txt in the same directory.
Option Explicit
Dim fso, objShell, objFolder, tFolder, tFile, toWrite, outFile
Dim currentFolder
Set fso=CreateObject("scripting.filesystemobject")
currentFolder = fso.GetAbsolutePathName(".")&"\"
Set tFolder = fso.getfolder(CurrentFolder)
Set objShell = CreateObject ("Shell.Application") 
Set objFolder = objShell.Namespace(Currentfolder) 
Set outFile = fso.createtextFile(CurrentFolder & "PictureInfo.txt",1,1)
 
 
For each tFile in tFolder.files
If UCase(FileExt(tFile.name)) = "JPG" Then
     toWrite = "File Name:" & objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 0)  & ";" & _
               "Date Taken:" & objFolder.GetDetailsOf(objFolder.Parsename(tFile.name), 25)  & ";"
outFile.writeline toWrite
     
'Extended file properties:
'0 Name 
'1 Size 
'2 Type 
'3 Date Modified 
'4 Date Created 
'5 Date Accessed 
'6 Attributes 
'7 Status 
'8 Owner 
'9 Author 
'10 Title 
'11 Subject 
'12 Category 
'13 Pages 
'14 Comments 
'15 Copyright 
'16 Artist 
'17 Album Title 
'18 Year 
'19 Track Number 
'20 Genre 
'21 Duration 
'22 Bit Rate 
'23 Protected 
'24 Camera Model 
'25 Date Picture Taken 
'26 Dimensions 
'27 
'28 
'29 Episode Name 
'30 Program Description 
'31 
'32 Audio sample size 
'33 Audio sample rate 
'34 Channels 
'35 Company 
'36 Description 
'37 File Version 
'38 Product Name 
'39 Product Version 
'40 Keywords 
End If
 
Next
outFile.close
Set outFile=Nothing
Set fso=Nothing
Set tFolder = Nothing
Set tFile = Nothing
Set objFolder = Nothing
 
Function FileExt(FileName)
FileExt = Right(FileName, Len(FileName)-instrrev(FileName,"."))
End Function

Open in new window

0
 

Author Comment

by:Hoogendoorn
ID: 22607899
Unfortunately Karen's Directory Printer does not cover JPG-attributes.
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22607928
May want to change:

If UCase(FileExt(tFile.name)) = "JPG" Then

To:

If UCase(FileExt(tFile.name)) = "JPG" or UCase(FileExt(tFile.name)) = "JPEG" Then
0
 

Author Comment

by:Hoogendoorn
ID: 22607947
This seems OK, Brandon. One more request: is it also possible to add the seconds to the time?
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22608144
If it's not there, then no.  Most camera's don't have the concept of seconds anyway.
0
 

Author Comment

by:Hoogendoorn
ID: 22608348
Mmmm, when I look in File Info in Adobe Photoshop Elements the seconds are also displayed, so they should be there.
0
 
LVL 39

Expert Comment

by:BrandonGalderisi
ID: 22608558
"If it's not there"

obviously  shell.application.Namespace.GetDetailsOf doesn't display that though.
0
 

Author Comment

by:Hoogendoorn
ID: 22608590
Well, that's a pitty. Anyway, I accept the second VBS you supplied as solution. Tanks.
0

Featured Post

U.S. Department of Agriculture and Acronis Access

With the new era of mobile computing, smartphones and tablets, wireless communications and cloud services, the USDA sought to take advantage of a mobilized workforce and the blurring lines between personal and corporate computing resources.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

cPanel is a Unix based web hosting control panel that provides a graphical interface and automation tools designed to simplify the process of hosting a web site. cPanel utilizes a 3 tier structure that provides functionality for administrators, rese…
We have adopted the strategy to use Computers in Student Labs as the bulletin boards. The same target can be achieved by using a Login Notice feature in Group policy but it’s not as attractive as graphical wallpapers with message which grabs the att…
Two types of users will appreciate AOMEI Backupper Pro: 1 - Those with PCIe drives (and haven't found cloning software that works on them). 2 - Those who want a fast clone of their boot drive (no re-boots needed) and it can clone your drive wh…
Add bar graphs to Access queries using Unicode block characters. Graphs appear on every record in the color you want. Give life to numbers. Hopes this gives you ideas on visualizing your data in new ways ~ Create a calculated field in a query: …

734 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question