Как извлечь данные EXIF в CSV-файл?
import pyexiv2
import os
print "Enter the full path to the directory that your images are conatined in."
print "-------------------------------------------"
newFileObj = open('C:\\users\\wilson\\desktop\\Metadata.csv', 'w')
targ_dir = raw_input('Path: ')
targ_files = os.listdir(targ_dir)
def getEXIFdata (imageFile):
if imageFile.endswith(".db"):
f = 1
else:
EXIFData = pyexiv2.ImageMetadata(imageFile)
EXIFData.read()
CamMake = EXIFData['Exif.Image.Make']
DateTime = EXIFData['Exif.Image.DateTime']
CamModel = EXIFData['Exif.Image.Model']
for image in targ_files:
getEXIFdata(targ_dir+"\\"+img)
newFileObj.write(DateTime+' , '+CamMake+' , '+CamModel+'\r\n')
newFileObj.close()
end = raw_input("Press Enter to Finish: ")
Это то, что я имею до сих пор, но я просто не понимаю, как на самом деле получить данные в файл. Он создает файл, но он просто пустой. Я пытался двигаться вокруг дна, но я просто не могу заставить его работать. Я новичок в Python, поэтому, пожалуйста, не могли бы вы быть проще, когда намекаете на то, что я должен делать.
1 ответ
Если вы хотите получить данные exif, используйте .value
чтобы получить значение данных. Вот пример.
# -*-coding:utf-8-*-
import sys
import csv
import os
import argparse
import pyexiv2
def main():
parser = argparse.ArgumentParser(description="Change the txt file to csv.")
parser.add_argument("-i", action="store", dest="infile")
parser.add_argument("-o", action="store", dest="outfile")
parser_argument = parser.parse_args()
fatherdir = os.getcwd() # code directory
inputfile = outputfile = None
# input exif file
if parser_argument.infile:
infilepaths = os.path.split(parser_argument.infile)
# 'C:\User\lenovo\Desktop\pakistan.txt' ---> ['C:\User\lenovo\Desktop','pakistan.txt']
if infilepaths[0]: # full path
inputfile = parser_argument.infile
fatherdir = infilepaths[0]
# 'pakistan.txt' ---> ['','pakistan.txt']
else: # only file name
inputfile = fatherdir + '/' + parser_argument.infile
# output csv file
if parser_argument.outfile:
outfilepaths = os.path.split(parser_argument.outfile)
if outfilepaths[0]: # full path
outputfile = parser_argument.outfile
else:
outputfile = fatherdir + '/' + parser_argument.outfile
else:
outputfile = fatherdir + '/test_csv.csv'
parse(inputfile, outputfile)
def parse(inputfile, outputfile):
csvcontent = file(outputfile, 'wb')
writer = csv.writer(csvcontent)
exif_data = getEXIFdata(inputfile)
writer.writerow([exif_data['Exif.Image.Orientation'].value,
exif_data['Exif.Photo.PixelXDimension'].value,
exif_data['Exif.Photo.PixelYDimension'].value])
# for line in open(inputfile).readlines():
# writer.writerow([a for a in line.split('\t')])
csvcontent.close()
def getEXIFdata (imageFile):
if imageFile.endswith(".db"):
print 'Skip this file'
else:
exif_data = pyexiv2.ImageMetadata(imageFile)
exif_data.read()
for s, v in exif_data.items():
print s, v
cam_a = exif_data['Exif.Image.Orientation'].value
cam_b = exif_data['Exif.Photo.PixelXDimension'].value
cam_c = exif_data['Exif.Photo.PixelYDimension'].value
# add exif value
ekey = 'Exif.Photo.UserComment'
evalue = 'A comment.'
exif_data[ekey] = pyexiv2.ExifTag(ekey, evalue)
#metadata.write()
return exif_data
if __name__ == '__main__':
main()
запустите этот код следующим образом
python exif2csv.py -i wifi.jpg -o demo_csv.csv
Если вы хотите зациклить файлы в каталоге, я думаю, что вы можете понять это самостоятельно.