python提取照片坐标信息的实例代码


Posted in Python onAugust 14, 2019

python提取照片坐标信息的代码如下所示:

from PIL import Image
from PIL.ExifTags import TAGS
import os
output="Z://result.csv"
out=open(output,'a')
out.write('lat,lon\n')
fpath="Z://iphonephoto"
for item in os.walk(fpath):
 ob=item[2]
 for i in ob:
  name=fpath+'/'+str(i)
  ret={}
  try:
   img=Image.open(name)
   if hasattr(img,'_getexif'):
    exifinfo=img._getexif()
    if exifinfo !=None:
     for tag,value in exifinfo.items():
      decoded=TAGS.get(tag,tag)
      ret[decoded]=value
      N1 = ret['GPSInfo'][2][0][0]
      N2 = ret['GPSInfo'][2][1][0]
      N3 = ret['GPSInfo'][2][2][0]
      N=int(N1)+int(N2)*(1.0/60)+int(N3)*(1.0/360000)
      E1 = ret['GPSInfo'][4][0][0]
      E2 = ret['GPSInfo'][4][1][0]
      E3 = ret['GPSInfo'][4][2][0]
      E=int(E1)+int(E2)*(1.0/60)+int(E3)*(1.0/360000)
      out.write(str(N)+','+str(E)+'\n')
  except:
   pass
out.close()

PS:Python小列子-读取照片位置

Python exifread

Python利用exifread库来解析照片的经纬度,对接百度地图API显示拍摄地点。

import exifread
import re
import json
import requests
def latitude_and_longitude_convert_to_decimal_system(*arg):
 """
 经纬度转为小数, 作者尝试适用于iphone6、ipad2以上的拍照的照片,
 :param arg:
 :return: 十进制小数
 """
 return float(arg[0]) + ((float(arg[1]) + (float(arg[2].split('/')[0]) / float(arg[2].split('/')[-1]) / 60)) / 60)
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}
def find_address_from_GPS(GPS):
 print(GPS)
 """
 使用Geocoding API把经纬度坐标转换为结构化地址。
 :param GPS:
 :return:
 """
 secret_key = 'xxxxxxxxxxxxxxxxxxxx'    # 百度地图创应用的秘钥 
 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]
 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"]
 return formatted_address
GPS_info = find_GPS_image(pic_path='lllll.jpg')  # 照片
address = find_address_from_GPS(GPS=GPS_info)
print(address)

总结

以上所述是小编给大家介绍的python提取照片坐标信息的实例代码 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Python 相关文章推荐
在Python中使用__slots__方法的详细教程
Apr 28 Python
python数据结构之链表详解
Sep 12 Python
Django自定义manage命令实例代码
Feb 11 Python
numpy使用fromstring创建矩阵的实例
Jun 15 Python
python清除函数占用的内存方法
Jun 25 Python
Python 比较文本相似性的方法(difflib,Levenshtein)
Oct 15 Python
为什么Python中没有"a++"这种写法
Nov 27 Python
python实现两个字典合并,两个list合并
Dec 02 Python
TensorFlow中如何确定张量的形状实例
Jun 23 Python
超级实用的8个Python列表技巧
Aug 24 Python
详解Python中的Lock和Rlock
Jan 26 Python
PyCharm常用配置和常用插件(小结)
Feb 06 Python
python2使用bs4爬取腾讯社招过程解析
Aug 14 #Python
详解用python计算阶乘的几种方法
Aug 14 #Python
Python使用scrapy爬取阳光热线问政平台过程解析
Aug 14 #Python
用Python抢火车票的简单小程序实现解析
Aug 14 #Python
Python定时任务随机时间执行的实现方法
Aug 14 #Python
查看Python依赖包及其版本号信息的方法
Aug 13 #Python
使用python实现unix2dos和dos2unix命令的例子
Aug 13 #Python
You might like
让Json更懂中文(JSON_UNESCAPED_UNICODE)
2011/10/27 PHP
Fatal error: Allowed memory size of 134217728 bytes exhausted (tried to allocate 2611816 bytes)
2014/11/08 PHP
PHP和MySql中32位和64位的整形范围是多少
2016/02/18 PHP
PHP+MariaDB数据库操作基本技巧备忘总结
2018/05/21 PHP
Code:loadScript( )加载js的功能函数
2007/02/02 Javascript
图片连续滚动代码[兼容IE/firefox]
2009/06/11 Javascript
json 入门基础教程 推荐
2009/10/31 Javascript
extjs表格文本启用选择复制功能具体实现
2013/10/11 Javascript
window.location不跳转的问题解决方法
2014/04/17 Javascript
新手快速学习JavaScript免费教程资源汇总
2015/06/25 Javascript
详解javascript实现自定义事件
2016/01/19 Javascript
jQuery基础_入门必看知识点
2016/07/04 Javascript
微信小程序网络请求的封装与填坑之路
2017/04/01 Javascript
关于Stream和Buffer的相互转换详解
2017/07/26 Javascript
VUE长按事件需求详解
2017/10/18 Javascript
ES6解构赋值实例详解
2017/10/31 Javascript
JS 实现微信扫一扫功能
2018/09/14 Javascript
探秘vue-rx 2.0(推荐)
2018/09/21 Javascript
Vue实现拖放排序功能的实例代码
2019/07/08 Javascript
jQuery操作事件完整实例分析
2020/01/10 jQuery
JS实现烟花爆炸效果
2020/03/10 Javascript
在Python中使用__slots__方法的详细教程
2015/04/28 Python
Python中的左斜杠、右斜杠(正斜杠和反斜杠)
2016/08/30 Python
Python实现重建二叉树的三种方法详解
2018/06/23 Python
python数据结构学习之实现线性表的顺序
2018/09/28 Python
Python线程同步的实现代码
2018/10/03 Python
Python 读取用户指令和格式化打印实现解析
2019/09/02 Python
Django数据统计功能count()的使用
2020/11/30 Python
十佳大学生事迹材料
2014/01/29 职场文书
法律专业学生的自我评价
2014/02/07 职场文书
美术教学感言
2014/02/22 职场文书
企业党的群众路线教育实践活动学习心得体会
2014/10/31 职场文书
2015年设计师个人工作总结
2015/04/25 职场文书
三好学生主要事迹怎么写
2015/11/03 职场文书
初三语文教学反思
2016/03/03 职场文书
python爬虫之selenium库的安装及使用教程
2021/05/23 Python