mirror of
https://github.com/SoPat712/BeReal-Export-Manager.git
synced 2025-08-21 18:28:46 -04:00
add init_parser() and init_global_var() function
This commit is contained in:
45
main.py
45
main.py
@@ -1,7 +1,36 @@
|
||||
import json
|
||||
from exiftool import ExifToolHelper as et
|
||||
from shutil import copy2 as cp
|
||||
import datetime
|
||||
from datetime import datetime as dt
|
||||
import argparse
|
||||
|
||||
|
||||
def init_parser():
|
||||
parser = argparse.ArgumentParser(formatter_class=argparse.RawTextHelpFormatter)
|
||||
parser.add_argument('-t', '--timespan', type=str, help="Exports the given timespan\n"\
|
||||
"Valid format: 'DD.MM.YYYY-DD.MM.YYYY'\n"\
|
||||
"Wildcards can be used: 'DD.MM.YYYY-*'")
|
||||
parser.add_argument('-y', '--year', type=int, help="Exports the given year")
|
||||
|
||||
args = parser.parse_args()
|
||||
if args.year and args.timespan:
|
||||
print("Timespan will be prioritized")
|
||||
|
||||
return args
|
||||
|
||||
|
||||
def init_global_var(args: argparse.Namespace):
|
||||
global time_span
|
||||
|
||||
if args.timespan:
|
||||
temp_times = args.timespan.strip().split("-")
|
||||
time_span = ('*' if temp_times[0] == '*' else dt.strptime(temp_times[0], '%d.%m.%Y'),
|
||||
'*' if temp_times[1] == '*' else dt.strptime(temp_times[1], '%d.%m.%Y'))
|
||||
elif args.year:
|
||||
time_span = (dt(args.year, 1, 1), dt(args.year, 12, 31))
|
||||
|
||||
|
||||
|
||||
def get_img_filename(image: json):
|
||||
"""
|
||||
@@ -23,7 +52,7 @@ def apply_memory_on_imgs(memory: json):
|
||||
Makes a copy of the front and back images and adds information from the memory object as exif tags to the image
|
||||
"""
|
||||
memory_dt = get_datetime_from_str(memory['takenTime'])
|
||||
img_names = ["./out/%s_%s.webp" % (memory_dt.strftime('%Y-%m-%d_%H-%M-%S'), i) for i in ['front', 'back']]
|
||||
img_names = ["./out/%s_%s.webp" % (memory_dt.strftime('%Y-%m-%d_%H-%M-%S'), temp_times) for temp_times in ['front', 'back']]
|
||||
|
||||
cp("./Photos/post/%s" % get_img_filename(memory['frontImage']), img_names[0])
|
||||
cp("./Photos/post/%s" % get_img_filename(memory['backImage']), img_names[1])
|
||||
@@ -40,10 +69,20 @@ def apply_memory_on_imgs(memory: json):
|
||||
params=["-P", "-overwrite_original"])
|
||||
|
||||
|
||||
def export_images(memories: json):
|
||||
|
||||
|
||||
for temp_times in memories:
|
||||
apply_memory_on_imgs(temp_times)
|
||||
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
args = init_parser()
|
||||
init_global_var(args)
|
||||
|
||||
f = open('memories.json')
|
||||
|
||||
for i in json.load(f):
|
||||
apply_memory_on_imgs(i)
|
||||
# export_images(json.load(f))
|
||||
|
||||
f.close()
|
||||
|
Reference in New Issue
Block a user