机智的我,用Python俘获了女神芳心...

程序员小P利用Python解析照片的经纬度信息,成功定位并邂逅女神,揭秘代码背后的地理编码技术。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

与女神的赌约

小P是一名程序猿,暗恋公司女神A很久了。
但落花有意,流水无情。
可自从小P学习了Python,

从此走上了逆袭高富帅,赢取白富美的成功之路。

女神最近买了华为最新出的mate30Pro 5G版,经常会在公司群里发一些新手机拍的高清照片。小P发现了女神这个爱好,决定和女神打一个赌,用Python俘获女神的芳心!

小P对女神说,经常在微信群里看到你发照片,

咱们来打一个赌吧!
今天下班后,你随便找个地方,对着天空拍张照。
然后原地等我半小时,我就会出现在你的身边。
如果我做到了,就代表彼此有缘,

考虑做我女朋友好吗?


转角遇到爱

女神自然是不信喽,但本着好奇与恶作剧的心态,下班后专门坐车去了一个自己都比较陌生的地方,然后拍了一张天空的照片发给了小P。

当小P坐在电脑边收到女神的照片后,马上运行了早已准备好的一段代码。然后惊奇的事情发生了!


小P通过代码,解析出女神拍照的经纬度,然后通过百度地图的逆地理编码功能,很快确定了女神所处的位置。
骑上我心爱的小摩托,出发!!!20分钟后小P与女神转角相遇…


女神被这突如其来的缘分,惊得说不出话来,最终跟小P过上了没羞没臊的生活。全剧终…

获取照片地理位置

故事到这里结束了,但是小P是如何通过代码解析到女神的具体位置呢?如果人人都可以通过照片解析他人的位置,岂不是乱了套了!别急,想通过代码解析微信发送的照片地理位置,需要满足以下几点要求:

  1. 他人通过发送原图,传递的照片

  2. 相机拍照时,默认设置了GPS定位

  3. 非iphone手机(iphone的地理位置,不会保存在照片中)

现在的手机在拍照时,默认都是打开GPS地位的。那么你只需要确认朋友手机不是iphone的,然后让他给你发送原图就OK了。
但照片属性中,只是保存了经纬度,我们如何能通过经纬度逆推地理位置呢?此时我们需要使用到百度地图的逆地理编码工具:


接口很简单,我们简单注册后,创建一个针对地理位置解析的应用即可:

小P的逆天代码

说了这么多,最终的逆天代码发布出来,让大家也学着小P去和女神创造一份属于彼此的缘分吧!

# -*- coding: utf-8 -*-
# @Author   : 王翔
# @微信号   : King_Uranus
# @公众号    : 清风Python
# @GitHub   : https://github.com/BreezePython
# @Date     : 2019/12/3 23:33
# @Software : PyCharm
# @version  :Python 3.7.3
# @File     : Meetlove.py

import requests
import exifread


class GetPhotoInfo:
    def __init__(self, photo):
        self.photo = photo
        # 百度地图ak
        self.ak = 'nYPs4LQ9a4VhVxj55AD69K6zgsRy9o4z'
        self.location = self.get_photo_info()

    def get_photo_info(self, ):
        with open(self.photo, 'rb') as f:
            tags = exifread.process_file(f)
        try:
            # 打印照片其中一些信息
            print('拍摄时间:', tags['EXIF DateTimeOriginal'])
            print('照相机制造商:', tags['Image Make'])
            print('照相机型号:', tags['Image Model'])
            print('照片尺寸:', tags['EXIF ExifImageWidth'], tags['EXIF ExifImageLength'])
            # 纬度
            lat_ref = tags["GPS GPSLatitudeRef"].printable
            lat = tags["GPS GPSLatitude"].printable[1:-1].replace(" ", "").replace("/", ",").split(",")
            lat = float(lat[0]) + float(lat[1]) / 60 + float(lat[2]) / float(lat[3]) / 3600
            if lat_ref != "N":
                lat = lat * (-1)
            # 经度
            lon_ref = tags["GPS GPSLongitudeRef"].printable
            lon = tags["GPS GPSLongitude"].printable[1:-1].replace(" ", "").replace("/", ",").split(",")
            lon = float(lon[0]) + float(lon[1]) / 60 + float(lon[2]) / float(lon[3]) / 3600
            if lon_ref != "E":
                lon = lon * (-1)
        except KeyError:
            return "ERROR:请确保照片包含经纬度等EXIF信息。"
        else:
            print("经纬度:", lat, lon)
            return lat, lon

    def get_location(self):
        url = 'http://api.map.baidu.com/reverse_geocoding/v3/?ak={}&output=json' \
              '&coordtype=wgs84ll&location={},{}'.format(self.ak, *self.location)
        response = requests.get(url).json()
        status = response['status']
        if status == 0:
            address = response['result']['formatted_address']
            print('详细地址:', address)
        else:
            print('baidu_map error')


if __name__ == '__main__':
    Main = GetPhotoInfo('微信图片_20191203180732.jpg')
    Main.get_location()

网络安全不容忽视

通过这篇文章,大家也需要对网络安全有所警惕了!不要随便发送原图给你不熟悉的人,如需发送可以在照片中进行相关的编辑打码等操作,这样可以去除照片的地理位置信息。另外,朋友圈发布的图片,微信都做了转码处理,不用担心这点。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值