python如何使用exifread获取图片的经纬度信息

本文介绍了如何利用python的exifread库来读取图片的经纬度信息。通过示例代码展示了如何获取并解析图片的GPS信息,将度分秒格式的经纬度转换为小数形式。

python如何使用exifread获取图片的经纬度信息

废话不多说,直接进主题。先下载exifread包:pip install exifread

先看下我们的图片属性
在这里插入图片描述
直接上代码

import exifread

if __name__ == '__main__':
    f = open("D:\\IdeaPorject\\datasets\\Ir\\DJI_20210927093017_0001_T.JPG", 'rb')
    contents = exifread.process_file(f)

如此,我们获取到了该图片所有属性参数,
在这里插入图片描述

可以看到,返回值是一个字典,其中所有的属性都是IfdTag object;同时,我们也可以看到GPS信息:

  1. 如果仅做展示,直接获取、输出即可;
print("经度 =", contents["GPS GPSLongitude"], contents['GPS GPSLatitudeRef'])
print("纬度 =", contents["GPS GPSLatitude"], contents['GPS GPSLongitudeRef'])

在这里插入图片描述

  1. 若要对经纬度信息进一步计算,且仔细看这个结构;
    在这里插入图片描述

这里,我将对经纬度的‘度分秒’转换成小数,仅做展示:

 longitude = contents["GPS GPSLongitude"].values
 longitude_f = longitude[0].num/longitude[0].den + (longitude[1].num/longitude[1].den/60) + (longitude[2].num/longitude[2].den/3600)
 latitude = contents["GPS GPSLatitude"].values
 latitude_f = latitude[0].num/latitude[0].den + (latitude[1].num/latitude[1].den/60) + (latitude[2].num/latitude[2].den/3600)
 print("经度 =", longitude_f, contents['GPS GPSLatitudeRef'])
 print("纬度 =", latitude_f, contents['GPS GPSLongitudeRef'])

在这里插入图片描述
实际使用时,longitude[0]、[1](latitude)可以直接取.num值,对于Ratio的分数值稍加留意即可

阿里云 OSS 本身并不支持获取图片经纬度信息,但是你可以借助第三方库来实现该功能。 一种常用的方法是使用 ExifRead 库来读取图片的 Exif 信息,其中就包含了图片的 GPS 信息。具体操作步骤如下: 1. 安装 ExifRead 库:可以使用 pip install exifread 命令进行安装。 2. 从 OSS 中下载图片:可以使用 oss2 库来实现,具体代码如下: ```python import oss2 # 初始化 OSS 客户端 auth = oss2.Auth('<AccessKeyId>', '<AccessKeySecret>') bucket = oss2.Bucket(auth, '<Endpoint>', '<BucketName>') # 下载图片到本地 result = bucket.get_object('<ObjectName>') img_data = result.read() ``` 3. 使用 ExifRead 库读取图片的 GPS 信息:具体代码如下: ```python import exifread # 读取图片的 GPS 信息 tags = exifread.process_file(img_data) # 获取经纬度信息 lat_ref = tags['GPS GPSLatitudeRef'].printable lat = tags['GPS GPSLatitude'].values lon_ref = tags['GPS GPSLongitudeRef'].printable lon = tags['GPS GPSLongitude'].values # 将经纬度转换为十进制表示 lat_d = float(lat[0].num) / float(lat[0].den) + float(lat[1].num) / float(lat[1].den) / 60 + float(lat[2].num) / float(lat[2].den) / 3600 if lat_ref == 'S': lat_d = -lat_d lon_d = float(lon[0].num) / float(lon[0].den) + float(lon[1].num) / float(lon[1].den) / 60 + float(lon[2].num) / float(lon[2].den) / 3600 if lon_ref == 'W': lon_d = -lon_d print('经度:', lon_d) print('纬度:', lat_d) ``` 需要注意的是,该方法只能读取包含 GPS 信息图片,如果图片中没有 GPS 信息,则会报错。另外,由于该方法需要读取图片的二进制数据,因此不适用于大文件的处理。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值