mirror of
https://github.com/tcsenpai/pensieve.git
synced 2025-06-06 03:05:25 +00:00
Merge branch 'master' of https://github.com/arkohut/memos
This commit is contained in:
commit
a76adde798
@ -2,31 +2,33 @@ from PIL import Image
|
||||
import piexif
|
||||
from PIL.PngImagePlugin import PngInfo
|
||||
import json
|
||||
|
||||
from pathlib import Path
|
||||
|
||||
def write_image_metadata(image_path, metadata):
|
||||
img = Image.open(image_path)
|
||||
image_path_str = str(image_path)
|
||||
|
||||
if image_path.lower().endswith((".jpg", ".jpeg", ".tiff")):
|
||||
if image_path_str.lower().endswith((".jpg", ".jpeg", ".tiff")):
|
||||
exif_dict = piexif.load(image_path)
|
||||
updated_description = json.dumps(metadata).encode("utf-8")
|
||||
exif_dict["0th"][piexif.ImageIFD.ImageDescription] = updated_description
|
||||
exif_bytes = piexif.dump(exif_dict)
|
||||
img.save(image_path, exif=exif_bytes)
|
||||
elif image_path.lower().endswith(".png"):
|
||||
elif image_path_str.lower().endswith(".png"):
|
||||
metadata_info = PngInfo()
|
||||
metadata_info.add_text("Description", json.dumps(metadata))
|
||||
img.save(image_path, "PNG", pnginfo=metadata_info)
|
||||
elif image_path.lower().endswith(".webp"):
|
||||
elif image_path_str.lower().endswith(".webp"):
|
||||
img.save(image_path, "WebP", quality=85, metadata=json.dumps(metadata))
|
||||
else:
|
||||
print(f"Skipping unsupported file format: {image_path}")
|
||||
print(f"Skipping unsupported file format: {image_path_str}")
|
||||
|
||||
|
||||
def get_image_metadata(image_path):
|
||||
img = Image.open(image_path)
|
||||
image_path_str = str(image_path)
|
||||
|
||||
if image_path.lower().endswith((".jpg", ".jpeg", ".tiff")):
|
||||
if image_path_str.lower().endswith((".jpg", ".jpeg", ".tiff")):
|
||||
exif_dict = piexif.load(image_path)
|
||||
existing_description = exif_dict["0th"].get(
|
||||
piexif.ImageIFD.ImageDescription, b"{}"
|
||||
@ -35,18 +37,18 @@ def get_image_metadata(image_path):
|
||||
return json.loads(existing_description.decode("utf-8"))
|
||||
except json.JSONDecodeError:
|
||||
return {}
|
||||
elif image_path.lower().endswith(".png"):
|
||||
elif image_path_str.lower().endswith(".png"):
|
||||
existing_description = img.info.get("Description", "{}")
|
||||
try:
|
||||
return json.loads(existing_description)
|
||||
except json.JSONDecodeError:
|
||||
return {}
|
||||
elif image_path.lower().endswith(".webp"):
|
||||
elif image_path_str.lower().endswith(".webp"):
|
||||
existing_metadata = img.info.get("metadata", "{}")
|
||||
try:
|
||||
return json.loads(existing_metadata)
|
||||
except json.JSONDecodeError:
|
||||
return {}
|
||||
else:
|
||||
print(f"Unsupported file format: {image_path}")
|
||||
return None
|
||||
print(f"Unsupported file format: {image_path_str}")
|
||||
return None
|
@ -8,7 +8,7 @@ import win32gui
|
||||
import win32process
|
||||
import psutil
|
||||
from mss import mss
|
||||
from .utils import write_image_metadata
|
||||
from memos.utils import write_image_metadata
|
||||
import win32api
|
||||
import pywintypes
|
||||
import ctypes
|
||||
|
@ -12,7 +12,7 @@ from Quartz import (
|
||||
import json
|
||||
import imagehash
|
||||
import argparse
|
||||
from .utils import write_image_metadata
|
||||
from memos.utils import write_image_metadata
|
||||
|
||||
|
||||
def get_active_window_info():
|
||||
@ -186,4 +186,4 @@ def main():
|
||||
|
||||
|
||||
if __name__ == "__main__":
|
||||
main()
|
||||
main()
|
Loading…
x
Reference in New Issue
Block a user