diff --git a/engine/plugins/insert_image.py b/engine/plugins/insert_image.py index 11301c5..88fd27a 100644 --- a/engine/plugins/insert_image.py +++ b/engine/plugins/insert_image.py @@ -14,6 +14,11 @@ import time import platform +from icecream import ic +import sys +ic.configureOutput(outputFunction=lambda *a: print(*a, file=sys.stderr)) +ic.configureOutput(prefix='> ') + from geekbook.engine.conf import INSERT_IMAGE_TAG, INSERT_IMAGE_TAG2, SCREENSHOT_INBOX, SCREENSHOT_INBOX2,\ INSERT_IMAGE_TAG2_SUFFIX, INSERT_IMAGE_TAG_SUFFIX, INSERT_IMAGE_HASHTAG, INSERT_IMAGE_HASHTAG2,\ INSERT_IMAGE_TAG3, SCREENSHOT_INBOX3, INSERT_IMAGE_TAG3_SUFFIX, INSERT_IMAGE_HASHTAG3 @@ -258,7 +263,6 @@ def insert_image(d = '/Users/magnus/Desktop/', td = '/home/magnus/Dropbox/geekbo else: return 'error of import, any file not found' - def get_creation_time_via_stat(fn): import pathlib try: @@ -271,9 +275,14 @@ def get_creation_time_via_stat(fn): return str(ctime).replace('-', '').replace(' ', '-')[2:].replace(':', '.') # to remove year ;-) lame def get_creation_time(fn): - dat = get_creation_time_via_pil(fn) + """ function to wrap on time""" + return get_date_exiftool(fn) # for screenshots etc + # !!!!!!!!!!!! # + if not dat: + dat = get_creation_time_via_pil(fn) if not dat: dat = get_creation_time_via_stat(fn) + return dat def get_creation_time_v3(filepath): @@ -286,7 +295,7 @@ def get_creation_time_v3(filepath): datetime_str = l.split("= ")[1] print(datetime_str) # ugly fix for time one +1 - d = datetime.datetime.strptime(datetime_str, "%Y-%m-%d %H:%M:%S +0000") + timedelta(hours=1) + d = datetime.datetime.strptime(datetime_str, "%Y-%m-%d %H:%M:%S +0000") + datetime.timedelta(hours=2) print(d) return str(d.strftime('%y%m%d')), str(d.strftime('%H%M')) raise DateNotFoundException("No EXIF date taken found for file %s" % filepath) @@ -307,28 +316,75 @@ def get_creation_time_v2(fn): except: print(fn) return ('error', '') - +def get_date_exiftool(fn): + """pyexiftool https://pypi.org/project/PyExifTool/""" + import exiftool + files = [fn] + ic(fn) + with exiftool.ExifToolHelper() as et: + metadata = et.get_metadata(files) + + d = '' + for d in metadata: + try: + d = d["EXIF:DateTimeOriginal"].replace(' ', '-').replace(':', '').replace(':', '.')[2:] + '_v2' # remove the year [2:] + #print("{:20.20} {:20.20}".format(d["SourceFile"], d["EXIF:DateTimeOriginal"])) # example + except KeyError: # if not date then this + d = d["File:FileAccessDate"].replace(' ', '-').replace(':', '').replace(':', '.')[2:] + '_v2' + return d + +def get_date_file(fn): + cmd = "file '" + fn + "'" + output = subprocess.check_output(cmd, shell = True) + #os.system() + # datetime= + import re + #x = str(output).split('datetime=')[1].split('image')[0].replace(':', '').strip().replace(' ', '-') + #return x + print(output) + print(str(output).split(',')) + for i in str(output).split(','): + print('dupa', i) + #if 'datetime': + # d = i.strip().replace('datetime=','') #2021:09:16 19:39:41 + # ic(d) + # return d + #r = re.findall(r'datetime=(?P