2023-03-04 21:08:42 +00:00
|
|
|
"""
|
2023-03-11 22:14:03 +00:00
|
|
|
OnlyLegs - Metadata Parser
|
2023-03-04 21:08:42 +00:00
|
|
|
Parse metadata from images if available
|
|
|
|
otherwise get some basic information from the file
|
|
|
|
"""
|
|
|
|
import os
|
|
|
|
|
|
|
|
from PIL import Image
|
2023-03-05 16:22:11 +00:00
|
|
|
from PIL.ExifTags import TAGS
|
2023-03-04 21:08:42 +00:00
|
|
|
|
|
|
|
from .helpers import *
|
|
|
|
from .mapping import *
|
|
|
|
|
2023-03-11 22:14:03 +00:00
|
|
|
|
2023-03-04 21:08:42 +00:00
|
|
|
class Metadata:
|
|
|
|
"""
|
|
|
|
Metadata parser
|
|
|
|
"""
|
|
|
|
def __init__(self, file_path):
|
|
|
|
"""
|
|
|
|
Initialize the metadata parser
|
|
|
|
"""
|
|
|
|
self.file_path = file_path
|
|
|
|
img_exif = {}
|
|
|
|
|
|
|
|
try:
|
|
|
|
file = Image.open(file_path)
|
|
|
|
tags = file._getexif()
|
|
|
|
img_exif = {}
|
|
|
|
|
|
|
|
for tag, value in TAGS.items():
|
|
|
|
if tag in tags:
|
|
|
|
img_exif[value] = tags[tag]
|
|
|
|
|
|
|
|
img_exif['FileName'] = os.path.basename(file_path)
|
|
|
|
img_exif['FileSize'] = os.path.getsize(file_path)
|
|
|
|
img_exif['FileFormat'] = img_exif['FileName'].split('.')[-1]
|
|
|
|
img_exif['FileWidth'], img_exif['FileHeight'] = file.size
|
|
|
|
|
|
|
|
file.close()
|
|
|
|
except TypeError:
|
|
|
|
img_exif['FileName'] = os.path.basename(file_path)
|
|
|
|
img_exif['FileSize'] = os.path.getsize(file_path)
|
|
|
|
img_exif['FileFormat'] = img_exif['FileName'].split('.')[-1]
|
|
|
|
img_exif['FileWidth'], img_exif['FileHeight'] = file.size
|
|
|
|
|
|
|
|
self.encoded = img_exif
|
|
|
|
|
|
|
|
def yoink(self):
|
|
|
|
"""
|
|
|
|
Yoinks the metadata from the image
|
|
|
|
"""
|
|
|
|
if not os.path.isfile(self.file_path):
|
|
|
|
return None
|
|
|
|
return self.format_data(self.encoded)
|
|
|
|
|
2023-03-11 22:14:03 +00:00
|
|
|
@staticmethod
|
|
|
|
def format_data(encoded_exif):
|
2023-03-04 21:08:42 +00:00
|
|
|
"""
|
|
|
|
Formats the data into a dictionary
|
|
|
|
"""
|
|
|
|
exif = {
|
|
|
|
'Photographer': {},
|
|
|
|
'Camera': {},
|
|
|
|
'Software': {},
|
|
|
|
'File': {},
|
|
|
|
}
|
2023-03-20 17:19:42 +00:00
|
|
|
|
2023-03-10 12:32:23 +00:00
|
|
|
# Thanks chatGPT xP
|
2023-04-02 17:00:32 +00:00
|
|
|
# pylint: disable=E0602
|
2023-03-20 17:57:47 +00:00
|
|
|
for key, value in encoded_exif.items():
|
2023-03-11 22:14:03 +00:00
|
|
|
for mapping_name, mapping_val in EXIF_MAPPING:
|
|
|
|
if key in mapping_val:
|
|
|
|
if len(mapping_val[key]) == 2:
|
|
|
|
exif[mapping_name][mapping_val[key][0]] = {
|
2023-03-10 12:32:23 +00:00
|
|
|
'raw': value,
|
2023-04-02 17:00:32 +00:00
|
|
|
'formatted': getattr(helpers, mapping_val[key][1])(value),
|
2023-03-04 21:08:42 +00:00
|
|
|
}
|
2023-03-10 12:32:23 +00:00
|
|
|
else:
|
2023-03-11 22:14:03 +00:00
|
|
|
exif[mapping_name][mapping_val[key][0]] = {
|
2023-03-10 12:32:23 +00:00
|
|
|
'raw': value,
|
2023-03-04 21:08:42 +00:00
|
|
|
}
|
2023-04-02 13:51:01 +00:00
|
|
|
continue
|
2023-03-04 21:08:42 +00:00
|
|
|
|
|
|
|
# Remove empty keys
|
2023-04-02 13:51:01 +00:00
|
|
|
if not exif['Photographer']:
|
2023-03-04 21:08:42 +00:00
|
|
|
del exif['Photographer']
|
2023-04-02 13:51:01 +00:00
|
|
|
if not exif['Camera']:
|
2023-03-04 21:08:42 +00:00
|
|
|
del exif['Camera']
|
2023-04-02 13:51:01 +00:00
|
|
|
if not exif['Software']:
|
2023-03-04 21:08:42 +00:00
|
|
|
del exif['Software']
|
2023-04-02 13:51:01 +00:00
|
|
|
if not exif['File']:
|
2023-03-04 21:08:42 +00:00
|
|
|
del exif['File']
|
|
|
|
|
|
|
|
return exif
|