用python就获取到照片拍摄时的详细位置【源码公开】

news/2024/5/19 20:20:28/文章来源:https://blog.csdn.net/weixin_52908342/article/details/122012234

文章目录

  • 一.引言
    • 1.读取照片信息,获取坐标
    • 2.通过baidu Map的API将GPS信息转换成地址。
  • 二.源码附上!!!
  • 注意事项

一.引言

先看获取到的效果

拍摄时间:2021:12:18 16:22:13
照片拍摄地址:('内蒙古自治区包头市昆都仑区', '内蒙古自治区', '包头市', '昆都仑区', '多米幼儿园东南360米')

在这里插入图片描述

我们的女朋友给我们发来一张照片我们如何获取到她的位置呢?
用手机拍照会带着GPS信息,原来没注意过这个,因此查看下并使用代码获取照片里的GPS信息
查看图片文件属性
在这里插入图片描述

1.读取照片信息,获取坐标

ExifRead

Python library to extract EXIF data from tiff and jpeg files.
安装

pip install exifread

读取GPS

import exifread
import redef read():GPS = {}date = ''f = open("C:\\Users\\24190\\Desktop\\小朱学长.jpg",'rb')contents = exifread.process_file(f)for key in contents:if key == "GPS GPSLongitude":print("经度 =", contents[key],contents['GPS GPSLatitudeRef'])elif key =="GPS GPSLatitude":print("纬度 =",contents[key],contents['GPS GPSLongitudeRef'])#print(contents)
read()

运行
在这里插入图片描述
我们得到了一个简易的gps地址
如果想要读取全部的拍摄信息:

# 读取照片的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}

2.通过baidu Map的API将GPS信息转换成地址。

众所周知gps和百度的经纬度会有误差,那么我们需要调用百度转换接口,这个百度目前没有开源。

# 通过baidu Map的API将GPS信息转换成地址。
def find_address_from_GPS(GPS):"""使用Geocoding API把经纬度坐标转换为结构化地址。:param GPS::return:"""secret_k ey = 'XXX'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, location

然后在主函数输出:
在这里插入图片描述

二.源码附上!!!

# coding=utf-8
'''
作者 : 小朱学长
微信公众号 : 八方支猿
'''
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_ke y = '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='小朱学长.jpg')address = find_address_from_GPS(GPS=GPS_info)print("拍摄时间:" + GPS_info.get("date_information"))print('照片拍摄地址:' + str(address))

注意事项

1.照片的地址信息等,一般的手机相机默认是打开的。
2.微信和QQ里面发送原图,信息都会完整的保留下来。
3.代码里面需要处理在照片我放到了代码的同文件夹下,所以没有写路径,大家可以自己写路径,或者放到于代码相同的路径下即可。
(有任何问题的话,欢迎评论区或者私信我嗷,我都会看的!)
❤️❤️❤️如果你喜欢的话,就不要吝惜你的一键三连了~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_224104.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

广和通5G AIoT模组引领亮相2022国际物联网展(IOTE),智赋行业数字化新价值

11月15-17日,2022国际物联网展(IOTE)于深圳盛大启幕,本届展会汇聚众多物联网行业大咖,共同展示并探讨物联网产业链的创新实践与成果。广和通以“5GAIoT深度融合,创新智造未来”为主题亮相现场。本次广和通展…

2.10.2版本的青龙升级2.10.13及2.11.3版本的教程

重要提醒: 这个教程仅限使用我下面这个命令搭建的青龙面板使用 docker run -dit \--name QL \--hostname QL \--restart always \-p 5700:5700 \-v $PWD/QL/config:/ql/config \-v $PWD/QL/log:/ql/log \-v $PWD/QL/db:/ql/db \-v $PWD/QL/scripts:/ql/scripts \-…

HTML知识点总结篇(一)

src和href的区别 作用结果不同 src用于替换当前内容href用于在引用资源和当前文档之间建立链接 请求资源类型不同 在请求src资源时,会将其指向的资源下载并应用到文档中。常用于img/iframe/input/style/scripthref常用于建立当前元素和文档之间的链接。常用的有lin…

【EC200U】GPS定位

EC200U GPS定位GNSS模块quecgnss - 内置GNSSGNSS 功能初始化GNSS 工作状态获取GNSS开关GNSS定位数据获取实测案例拓展当前互联网地图的坐标系现状地球坐标 (WGS84)火星坐标 (GCJ-02)也叫国测局坐标系百度坐标 (BD-09)coordtransform 坐标转换EC系列东西很多,网上资料…

高精度算法【加减乘除】

全文目录😍 前言😀 高精度加法🤔 操作步骤😵‍💫 代码模板😀高精度减法🤔操作步骤😵‍💫 代码模板😀高精度乘法🤔操作步骤😵‍&#x…

基于SSM花卉商城设计与实现

项目描述 临近学期结束,还是毕业设计,你还在做java程序网络编程,期末作业,老师的作业要求觉得大了吗?不知道毕业设计该怎么办?网页功能的数量是否太多?没有合适的类型或系统?等等。这里根据疫情当下,你想解决的问…

记一道前端高难度面试题

目录 提问:如何让下面的这行代码成立 1.错误原因 2.思路 3.解题 4.小结 提问:如何让下面的这行代码成立 var [a,b] {a:1,b:2} 直接运行会报错,报错信息如下: Uncaught TypeError: {(intermediate value)(intermediate valu…

轻松学会jQuery选择器的用法

文章目录⛳️ 选择器✨ 属性选择器✨ 包含选择器✨ 位置选择器✨ 过滤选择器✨ 反向选择器⛳️ 快速投票⛳️ 选择器 本篇重点讲解jQuery中丰富的选择器,以及他们的基本用法。CSS的选择器均可以用jQuery的$进行选择,部分浏览器对CSS3的选择器支持不全&am…

【Pytorch with fastai】第 6 章 :其他计算机视觉问题

🔎大家好,我是Sonhhxg_柒,希望你看完之后,能对你有所帮助,不足请指正!共同学习交流🔎 📝个人主页-Sonhhxg_柒的博客_CSDN博客 📃 🎁欢迎各位→点赞…

都说测试行业饱和了,为什么我们公司给初级测试开到了12K?

故事起因: 最近我有个刚毕业的学生问我说:我感觉现在测试行业已经饱和了,也不是说饱和了,是初级的测试根本就没有公司要,哪怕你不要工资也没公司要你,测试刚学出来,没有任何的项目经验和工作经验…

MaxViT: Multi-Axis Vision Transformer

论文:https://arxiv.org/abs/2204.01697 代码地址:https://github.com/google-research/maxvit 在本文中,介绍了一种高效且可扩展的注意力模型,称之为多轴注意力,该模型由两个方面组成:分块的局部注意力和…

笔记本电脑没有声音如何解决

​笔记本电脑没有声音的现象,也是笔记本电脑的常见运用病况之一,遇到这种情况的话,大家是否知道如何处理呢?下面小编来跟大家说说笔记本电脑没有声音解决方法,希望可以帮助到大家。 工具/原料: 系统版本:windows10系统 品牌型…

Allegro 274X格式gerber输出全流程详细介绍

Allegro 274X格式gerber输出全流程详细介绍 下面介绍Allegro gerber输出的全流程介绍 首先把光绘设置好 设置光钻孔精度 会出现对话框,勾选Enhanced Excellon format,点击close 输出钻孔文件,选择Auto Tool select,点击Drill 输出椭圆孔文件,默认设置,然后点击rout…

Android App开发之利用Glide实现图片的三级缓存Cache讲解及实战(附源码 超详细必看 简单易懂)

需要图片集和源码请点赞关注收藏后评论区留言~~~ 一、利用Glide实现图片的三级缓存 图片加载框架之所以高效,是因为它不但封装了访问网络的步骤,而且引入了三级缓存的机制。具体来说,是先到内存中查找图片,找到了就直接显示内存图…

二级导航栏

简介&#xff1a;本文通过HTML与CSS相集合的方式&#xff0c;来实现二级导航菜单。 HTML构建骨架 <body><ul class"nav1"><li>水果<ul class"nav2"><li>苹果</li><li>香梨</li><li>火龙果</li…

windows常见的命令操作大全

目录 一、目录文件操作 cd命令 dir命令 md命令 rd命令 move命令 copy命令 del命令 二、文本相关操作 type命令 >命令 findstr命令 |命令 三、网络相关操作 小建议&#xff1a;跟着文章亲手敲一遍是避免忘记的有效方法 一、目录文件操作 cd命令 功能&#xf…

JavaScript流程控制-循环(循环(for 循环,双重 for 循环,while 循环,do while 循环,continue break))

目录 JavaScript流程控制-循环 循环 for 循环 执行过程&#xff1a; 断点调试&#xff1a; 案例一&#xff1a;求1-100之间所有整数的累加和 案例二&#xff1a;求1-100之间所有数的平均值 案例三&#xff1a;求1-100之间所有偶数和奇数的和 案例四&#xff1a;求1-10…

HashMap的面试题

目录 1、底层数据结构 1.7和1.8有何不同 2、为什么用红黑树&#xff0c;为何不一上来就树化&#xff0c;树化阈值为何是8&#xff0c;何时会树化&#xff0c;何时会退化为链表 3、索引如何计算&#xff1f;hashCode都有了&#xff0c;为何还要提供hash()方法&#xff1f;数组…

ArcGIS计算地形湿度指数

TWI是区域地形对径流流向和蓄积影响的物理指标&#xff0c;有助于识别降雨径流模式、潜在土壤含水量增加区域和积水区域。 计算方法&#xff1a;TWI是通过细尺度地形与上梯度对地表面积的贡献相互作用&#xff0c;根据以下关系得到的(Beven et al.,1979) [1] : TWI ln [CA/…

用专业团队管理软件工具轻松“拿捏”年轻运营团队

本文旨在抛砖引玉&#xff0c;欢迎大家拍砖讨论&#xff0c;通过一款时下流行的专业团队管理软件飞项做案例&#xff0c;一起探讨和交流团队管理专业工具软件和一些对应的方法论。 说到国内这几年流行起来的团队管理工具软件&#xff0c;我们先看看互联网这几年的发展。这几年&…