oops forgot to readd stuff cuz i moved it >~<
This commit is contained in:
parent
8ed5644f81
commit
fea0c31d08
9 changed files with 242 additions and 1 deletions
17
category/deviantart.py
Normal file
17
category/deviantart.py
Normal file
|
@ -0,0 +1,17 @@
|
|||
def makeKeyWordList(tags):
|
||||
catPaths = {
|
||||
'digitalart/paintings/other': ['Digital Art', 'Paintings']
|
||||
}
|
||||
output = [
|
||||
tags.da_category,
|
||||
tags.license,
|
||||
tags.author.username
|
||||
]
|
||||
|
||||
if tags.is_mature:
|
||||
output.append('is_mature')
|
||||
|
||||
|
||||
for item in .get(tags.category_path,[]):
|
||||
output.append(item)
|
||||
|
9
category/furaffinity.py
Normal file
9
category/furaffinity.py
Normal file
|
@ -0,0 +1,9 @@
|
|||
def makeKeyWordList(tags):
|
||||
return [
|
||||
tags.theme,
|
||||
tags.rating,
|
||||
tags.species,
|
||||
tags.gender,
|
||||
tags.artist_url,
|
||||
tags.fa_category
|
||||
]
|
2
main.py
2
main.py
|
@ -16,7 +16,7 @@ with open(f"{source}.json") as file:
|
|||
|
||||
# TODO: insert method to check url or dict
|
||||
logging.debug("determining file type...")
|
||||
import exif
|
||||
from standards import exif
|
||||
if infojson.extension in exif.allowed_exts:
|
||||
logging.debug(f"exif module supports {infojson.extesnion} files. using it... ")
|
||||
|
7
misc/getpub.py
Normal file
7
misc/getpub.py
Normal file
|
@ -0,0 +1,7 @@
|
|||
def getPub(input):
|
||||
if fa_category in input or input.category == 'furaffinity':
|
||||
return 'Furaffinity'
|
||||
elif input.category == 'deviantart':
|
||||
return 'DeviantArt'
|
||||
else:
|
||||
return 'Unknown'
|
81
standards/exif.py
Normal file
81
standards/exif.py
Normal file
|
@ -0,0 +1,81 @@
|
|||
import logging
|
||||
logging.basicConfig(stream=sys.stderr, level=logging.DEBUG)
|
||||
|
||||
allowed_exts=[
|
||||
"tif","tiff", # TIFF
|
||||
"jpeg","jpg","pjpeg","pjpg","jpe", # JPEG
|
||||
"webp", # Webp
|
||||
# "wav","wave", # RIFF Wave
|
||||
"png","apng" # PNG (since 1.2)
|
||||
]
|
||||
|
||||
def backupMetadata(file):
|
||||
from PIL import Image, ExifTags
|
||||
|
||||
logging.debug(f"loading file {file}")
|
||||
img = Image.open(file)
|
||||
logging.debug("file loaded. getting exif")
|
||||
img_exif = img.getexif()
|
||||
|
||||
full=[]
|
||||
|
||||
if img_exif is None:
|
||||
logging.warning("Could not load EXIF Data... Either something happened with Pillow, the file disappeared, or you don't have access to the file. Try running verbose!")
|
||||
break
|
||||
else:
|
||||
logging.debug("loaded tags")
|
||||
for key, val in img_exif.items():
|
||||
logging.debug(f"for key:'{key}', val:'{val}' in img_exif.items()")
|
||||
if key in ExifTags.TAGS:
|
||||
logging.debug(f"{key} is known exif tag! ({ExifTags.TAGS[key]})")
|
||||
full.append({
|
||||
'tagName': str(key),
|
||||
'realName': str(ExifTags.TAGS[key]),
|
||||
'value': str(val)
|
||||
})
|
||||
else:
|
||||
logging.warning(f"{key} is an unknown exif tag!")
|
||||
full.append({
|
||||
'tagName': str(key),
|
||||
'realName': None,
|
||||
'value': str(val)
|
||||
})
|
||||
|
||||
logging.info("writing backup data")
|
||||
import json
|
||||
|
||||
#import tempfile
|
||||
#temp = tempfile.TemporaryFile(mode='w+')
|
||||
#json.dump(full,temp,sort_keys=True)
|
||||
with open(f"{file}.exif_backup.json.xz",'w+b') as bfile
|
||||
logging.debug(f"writing to {bfile}")
|
||||
import lzma
|
||||
bfile.write(lzma.compress(
|
||||
bytes(json.dumps(full,sort_keys=True)),
|
||||
format=FORMAT_XZ,
|
||||
check=CHECK_SHA256,
|
||||
preset=9
|
||||
))
|
||||
logging.debug("wrote backup data")
|
||||
|
||||
logging.info("backup done!")
|
||||
|
||||
def writeTags(file,tags):
|
||||
from PIL import Image
|
||||
image=Image.open(file)
|
||||
exif = image.getexif()
|
||||
|
||||
if artist in tags:
|
||||
if type(tag.artist) == str:
|
||||
exif[0x013b] = tags.artist
|
||||
elif tags.category == "deviantart":
|
||||
exif[0x013b] = tags.artist.username
|
||||
|
||||
if title in tags:
|
||||
exif[0x0010e] = tags.title
|
||||
|
||||
if description in tags:
|
||||
exif[0x9286] = tags.description
|
||||
|
||||
|
||||
|
0
standards/iptc.py
Normal file
0
standards/iptc.py
Normal file
0
standards/matroska.py
Normal file
0
standards/matroska.py
Normal file
0
standards/png.py
Normal file
0
standards/png.py
Normal file
127
standards/xmp.py
Normal file
127
standards/xmp.py
Normal file
|
@ -0,0 +1,127 @@
|
|||
"XMP Manipulator for gallery-dl"
|
||||
import logging
|
||||
logging.basicConfig(stream=sys.stderr, level=logging.DEBUG)
|
||||
|
||||
allowed_exts=[
|
||||
"html", "htm", "xhtml", "xht", # HTML
|
||||
"tif", "tiff", # TIFF
|
||||
"jpeg", "jpg", "pjpeg", "pjpg", "jpe", # JPEG
|
||||
"jp2", "jpf", "jpx", "jpm", "mj2", # JPEG 2000
|
||||
"png", "apng", # PNG
|
||||
"gif", # GIF
|
||||
"mp3", # MPEG-1 / MPEG-2 Layer III
|
||||
"mp4", "m4a", "m4p", "m4b", "m4r", "m4v", # MPEG-4
|
||||
"mov", "qt", # Apple QuickTime .mov
|
||||
"pdf", # PDF
|
||||
"webp" # WebP
|
||||
]
|
||||
|
||||
# def backupMetadata(file: str, outputFileExt: str = "xmp_backup.json.xz") -> bool:
|
||||
# """Exports XMP metadata inside of a file.
|
||||
|
||||
# Parameters
|
||||
# ----------
|
||||
# file : str
|
||||
# Location of the file relative to the working directory.
|
||||
# outputFileExt : str, optional
|
||||
# The suffix used for the backup file. By default, the output file will be formatted as such:
|
||||
# <source filename>.xmp_backup.json.xz
|
||||
|
||||
# Returns
|
||||
# -------
|
||||
# bool
|
||||
# True, if operation was successful.
|
||||
# False, if operation failed.
|
||||
# """
|
||||
# from libxmp.utils import file_to_dict
|
||||
|
||||
# import json
|
||||
# with open(f"{file}.xmp_backup.json.xz",'w+b') as bfile
|
||||
# logging.debug(f"writing to {bfile}")
|
||||
# import lzma
|
||||
# bfile.write(lzma.compress(
|
||||
# bytes(json.dumps(file_to_dict(file),sort_keys=True)),
|
||||
# format=FORMAT_XZ,
|
||||
# check=CHECK_SHA256,
|
||||
# preset=9
|
||||
# ))
|
||||
# logging.debug("wrote backup data")
|
||||
|
||||
# logging.info("backup done!")
|
||||
|
||||
def backupMetadata(file):
|
||||
import pyexiv2
|
||||
data = pyexiv2.ImageMetadata(file)
|
||||
data.read()
|
||||
|
||||
full = []
|
||||
|
||||
for key in data.xmp_keys:
|
||||
full.append([
|
||||
key,
|
||||
data[key].raw_value
|
||||
])
|
||||
|
||||
with open(f"{file}.xmp_backup.json.xz",'w+b') as bfile
|
||||
import lzma, json
|
||||
bfile.write(lzma.compress(
|
||||
bytes(json.dumps(full)),
|
||||
format=FORMAT_XZ,
|
||||
check=CHECK_SHA256,
|
||||
preset=9
|
||||
))
|
||||
|
||||
# def writeTags(file: str, tags: dict) -> bool:
|
||||
# """Writes XMP tags to file taking the info.json file as a dict.
|
||||
|
||||
|
||||
# """
|
||||
# from libxmp import XMPFiles, consts
|
||||
# xmpfile = XMPFiles(file_path=file,)
|
||||
# if artist in tags:
|
||||
# if type(tags.artist) == str:
|
||||
# xmp.set_property(consts.XMP_NS_DC, u'creator', tags.artist.decode('unicode-escape'))
|
||||
|
||||
def writeTags(file, tags):
|
||||
import pyexiv2
|
||||
xmptags = pyexiv2.ImageMetadata(file)
|
||||
xmptags.read()
|
||||
|
||||
if artist in tags:
|
||||
if type(tag.artist) == str:
|
||||
xmptags['Xmp.dc.creator'] = tags.artist
|
||||
elif tags.category == "deviantart":
|
||||
xmptags['Xmp.dc.creator'] = tags.artist.username
|
||||
|
||||
if title in tags:
|
||||
xmptags['Xmp.dc.title'] = tags.title
|
||||
|
||||
if description in tags:
|
||||
xmptags['Xmp.dc.description'] = tags.description
|
||||
|
||||
if date in tags:
|
||||
xmptags['Xmp.dc.date'] = tags.date
|
||||
|
||||
from ..misc.getpub import getPub
|
||||
xmptags['Xmp.dc.publisher'] = getPub(tags)
|
||||
del getPub
|
||||
|
||||
keywords=[]
|
||||
|
||||
keywords.append(tags.category)
|
||||
|
||||
if tags in tags:
|
||||
for item in tags.tags:
|
||||
if item not in keywords: keywords.append(item)
|
||||
|
||||
if tags.category == 'deviantart':
|
||||
from ..category.deviantart import makeKeyWordList
|
||||
for item in makeKeyWordList(tags):
|
||||
if item not in keywords: keywords.append(item)
|
||||
elif tags.category == 'furaffinity':
|
||||
from ..category.furaffinity import makeKeyWordList
|
||||
for item in makeKeyWordList(tags):
|
||||
if item not in keywords: keywords.append(item)
|
||||
|
||||
|
||||
|
Loading…
Reference in a new issue