日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > python >内容正文

python

Python根据原图解析拍摄地点

發布時間:2025/3/19 python 39 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python根据原图解析拍摄地点 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
# -*- coding:utf-8 -*-''' fileName: createTime: modifyTime: description:written by donghao '''import exifread import re import json import requests import os#轉換經緯度格式 def latitude_and_longitude_convert_to_decimal_system(*arg):"""經緯度轉為小數, param arg::return: 十進制小數"""return float(arg[0]) + ((float(arg[1]) + (float(arg[2].split('/')[0]) / float(arg[2].split('/')[-1]) / 60)) / 60)#讀取照片的GPS經緯度信息 def find_GPS_image(pic_path):GPS = {}date = ''with open(pic_path, 'rb') as f:tags = exifread.process_file(f)for tag, value in tags.items():#緯度if re.match('GPS GPSLatitudeRef', tag):GPS['GPSLatitudeRef'] = str(value)#經度elif re.match('GPS GPSLongitudeRef', tag):GPS['GPSLongitudeRef'] = str(value)#海拔elif re.match('GPS GPSAltitudeRef', tag):GPS['GPSAltitudeRef'] = str(value)elif re.match('GPS GPSLatitude', tag):try:match_result = re.match('\[(\w*),(\w*),(\w.*)/(\w.*)\]', str(value)).groups()GPS['GPSLatitude'] = int(match_result[0]), int(match_result[1]), int(match_result[2])except:deg, min, sec = [x.replace(' ', '') for x in str(value)[1:-1].split(',')]GPS['GPSLatitude'] = latitude_and_longitude_convert_to_decimal_system(deg, min, sec)elif re.match('GPS GPSLongitude', tag):try:match_result = re.match('\[(\w*),(\w*),(\w.*)/(\w.*)\]', str(value)).groups()GPS['GPSLongitude'] = int(match_result[0]), int(match_result[1]), int(match_result[2])except:deg, min, sec = [x.replace(' ', '') for x in str(value)[1:-1].split(',')]GPS['GPSLongitude'] = latitude_and_longitude_convert_to_decimal_system(deg, min, sec)elif re.match('GPS GPSAltitude', tag):GPS['GPSAltitude'] = str(value)elif re.match('.*Date.*', tag):date = str(value)return {'GPS_information': GPS, 'date_information': date}#通過baidu Map的API將GPS信息轉換成地址。 def find_address_from_GPS(GPS):"""使用Geocoding API把經緯度坐標轉換為結構化地址。:param GPS::return:"""secret_key = 'zbLsuDDL4CS2U0M4KezOZZbGUY9iWtVf'if not GPS['GPS_information']:return '該照片無GPS信息'lat, lng = GPS['GPS_information']['GPSLatitude'], GPS['GPS_information']['GPSLongitude']baidu_map_api = "http://api.map.baidu.com/geocoder/v2/?ak={0}&callback=renderReverse&location={1},{2}s&output=json&pois=0".format(secret_key, lat, lng)response = requests.get(baidu_map_api)content = response.text.replace("renderReverse&&renderReverse(", "")[:-1]print(content)baidu_map_address = json.loads(content)formatted_address = baidu_map_address["result"]["formatted_address"]province = baidu_map_address["result"]["addressComponent"]["province"]city = baidu_map_address["result"]["addressComponent"]["city"]district = baidu_map_address["result"]["addressComponent"]["district"]location = baidu_map_address["result"]["sematic_description"]return formatted_address,province,city,district,locationif __name__ == '__main__':GPS_info = find_GPS_image(pic_path='E:\Desktop/1.jpg')address = find_address_from_GPS(GPS=GPS_info)print("拍攝時間:" + GPS_info.get("date_information"))print('照片拍攝地址:' + str(address))

總結

以上是生活随笔為你收集整理的Python根据原图解析拍摄地点的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。