47 lines
1.2 KiB
Python
47 lines
1.2 KiB
Python
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
|
|
return decimal_degrees
|
|
|
|
def extract_location(filepath: str) -> dict:
|
|
"""Get location data from image
|
|
|
|
### Args:
|
|
* filepath (`str`): Path to file location
|
|
|
|
### Returns:
|
|
* dict: `{ "latitude": float, "longitude": float, "altitude": float }`
|
|
"""
|
|
|
|
output = {
|
|
"latitude": 0.0,
|
|
"longitude": 0.0,
|
|
"altitude": 0.0
|
|
}
|
|
|
|
with open(filepath, 'rb') as src:
|
|
img = Image(src)
|
|
|
|
if img.has_exif is False:
|
|
return output
|
|
|
|
try:
|
|
output["latitude"] = decimal_coords(img.gps_latitude, img.gps_latitude_ref)
|
|
output["longitude"] = decimal_coords(img.gps_longitude, img.gps_longitude_ref)
|
|
output["altitude"] = img.gps_altitude
|
|
except AttributeError:
|
|
pass
|
|
|
|
return output |