1.前序
有的照片是带有GPS定位信息的,我们就是通过这个信息去通过高德定位图片的拍摄地址
右键照片属性-->查看详细信息,我们可以看到照片的GPS定位信息。
2.
在写代码之前,我们还需要准备调取高德地图得KEY,通过该KEY去调用高德接口,解析经纬度成我们所理解的地址信息。(具体如何创建调用KEY,可以参考我前几篇对高德API接口使用示例)
此外,我们还需要借助Python的exifread模块包功能读取照片属性
读取照片属性,获取经纬度,拍摄时间等。
# 利用exifread库,读取图片的属性
img_exif = exifread.process_file(open(self.img_path, 'rb'))
# 能够读取到属性
if img_exif:
# 纬度数
latitude_gps = img_exif['GPS GPSLatitude']
# N,S 南北纬方向
latitude_direction = img_exif['GPS GPSLatitudeRef']
# 经度数
longitude_gps = img_exif['GPS GPSLongitude']
# E,W 东西经方向
longitude_direction = img_exif['GPS GPSLongitudeRef']
# 拍摄时间
take_time = img_exif['EXIF DateTimeOriginal']
我们需要关注能否拿到这几个关键词数据。
GPS GPSLatitude,GPS GPSLongitude,EXIF DateTimeOriginal
'GPS GPSLongitude': (0x0004) Ratio=[114, 7, 4813/100] @ 1900
'GPS GPSLatitude': (0x0002) Ratio=[22, 30, 811/100] @ 1876
根据图片拿到的经纬度,我们无法通过高德API确定位置,还需进一步做数据处理。
if latitude_gps and longitude_gps and take_time:
# 对纬度、经度值原始值作进一步的处理
latitude = self.__format_lati_long_data(latitude_gps)
longitude = self.__format_lati_long_data(longitude_gps)
# print(f'{longitude},{latitude}')
# 注意:由于gps获取的坐标在国内高德等主流地图上逆编码不够精确,这里需要转换为火星坐标系
location = wgs84togcj02(longitude, latitude)
处理后的经纬度
获取到经度、纬度是:114.13511208995212,22.49954944216219
获取到经纬度后,接下来就是要通过高德API转换成我们能看懂的地址。(需要申请KEY),高德官网
resp = requests.get(self.url_get_position.format(self.api_key, location))
location_data = json.loads(resp.text)
address = location_data.get('regeocode').get('formatted_address')
return address
这时候我们就能知道这张照片拍摄时间及地址。
最后
微信和qq的照片在发送出来后,已经对GPS信息做了屏蔽处理。所以大家现在不用太担心自己的位置被获取到。
更多源码信息请参考原文