PhotosAPI/modules/exif_reader.py

47 lines
1.2 KiB
Python
Raw Normal View History

2023-01-02 14:10:10 +02:00
from exif import Image
def decimal_coords(coords: float, ref: str) -> float:
"""Get latitude/longitude from coord and direction reference
### Args:
* coords (`float`): _description_
* ref (`str`): _description_
### Returns:
* float: Decimal degrees
"""
decimal_degrees = coords[0] + coords[1] / 60 + coords[2] / 3600
if ref == "S" or ref == "W":
decimal_degrees = -decimal_degrees
2023-01-02 16:08:46 +02:00
return round(decimal_degrees, 5)
2023-01-02 14:10:10 +02:00
def extract_location(filepath: str) -> dict:
"""Get location data from image
### Args:
* filepath (`str`): Path to file location
### Returns:
2023-01-02 16:08:46 +02:00
* dict: `{ "lng": float, "lat": float, "alt": float }`
2023-01-02 14:10:10 +02:00
"""
output = {
2023-01-02 16:08:46 +02:00
"lng": 0.0,
"lat": 0.0,
"alt": 0.0
2023-01-02 14:10:10 +02:00
}
with open(filepath, 'rb') as src:
img = Image(src)
if img.has_exif is False:
return output
try:
2023-01-02 16:08:46 +02:00
output["lng"] = decimal_coords(img.gps_longitude, img.gps_longitude_ref)
output["lat"] = decimal_coords(img.gps_latitude, img.gps_latitude_ref)
output["alt"] = img.gps_altitude
2023-01-02 14:10:10 +02:00
except AttributeError:
pass
return output