自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

女朋友背著我,用 Python 偷偷隱藏了她的行蹤

開發(fā) 后端
女朋友會 Python 是多么可怕的一件事!上篇文章發(fā)布之后,一位朋友告訴忽略了一件事,假設(shè)女朋友會 Python 的話,那豈不是要翻車?如果是這樣的話,女朋友發(fā)過來的圖片包含的地理位置是否真實(shí),要打一個(gè) Big Big 的問號了?

1.目標(biāo)場景

女朋友會 Python 是多么可怕的一件事!

[[282840]]

上篇文章發(fā)布之后,一位朋友告訴忽略了一件事,假設(shè)女朋友會 Python 的話,那豈不是要翻車?如果是這樣的話,女朋友發(fā)過來的圖片包含的地理位置是否真實(shí),要打一個(gè) Big Big 的問號了?

實(shí)際上,利用 Python 是可以非常方便地修改一張圖片的地理位置。

2.編寫代碼

在編寫腳本之前,需要在虛擬環(huán)境下安裝依賴庫:piexif

第一步,我們讀取原圖的經(jīng)度和緯度,然后將地理位置格式化為浮點(diǎn)類型。

拿到 GPS 圖片坐標(biāo)之后,需要轉(zhuǎn)為火星坐標(biāo)系數(shù)據(jù)。

 

  1. def read_image(self, image_path): 
  2.     ""
  3.     開始處理圖片 
  4.     exifread:讀取圖片屬性 
  5.     :return
  6.     ""
  7.     exif_dict = piexif.load(image_path) 
  8.  
  9.     if exif_dict['GPS']: 
  10.  
  11.          # 緯度 
  12.          gps_lati_pre = exif_dict['GPS'][2] 
  13.  
  14.          gps_lati = dms_to_gps(gps_lati_pre) 
  15.  
  16.          # 經(jīng)度 
  17.          gps_long_pre = exif_dict['GPS'][4] 
  18.          gps_long = dms_to_gps(gps_long_pre) 
  19.  
  20.          # GPS坐標(biāo)轉(zhuǎn)為高德坐標(biāo) 
  21.          lng, lat = wgs84togcj02(gps_long, gps_lati) 
  22.  
  23.          print(f"原圖地理位置如下\n經(jīng)度:{lng}\n緯度:{lat}\n"
  24.  
  25.          return f'{lng}, {lat}' 
  26.     else
  27.          print(f'抱歉!這張圖片不包含地理位置!'

第二步,利用高德 Web 服務(wù) API 中的 逆地理編碼 解析出原圖的詳細(xì)位置。

 

  1. def get_address_by_location(self, location): 
  2.     ""
  3.     通過經(jīng)緯度拿到地理位置 
  4.     :param location: 
  5.     :return
  6.     ""
  7.     params = { 
  8.        'key': self.ak, 
  9.         'location': location, 
  10.         'sig': self.sign 
  11.     } 
  12.  
  13.     resp = json.loads(requests.get(url=self.url_regeo, params=params).text) 
  14.  
  15.     if resp and resp.get('regeocode'and resp.get('regeocode').get('formatted_address'): 
  16.          address = resp.get('regeocode').get('formatted_address'
  17.          print(f'原圖的拍攝地址為:{address}\n'
  18.     else
  19.          print('api解析地址出錯,請檢查ak!\n'

第三步,尋找一個(gè)要定位的地理位置。

首先,輸入目標(biāo)城市和具體地址,利用高德 Web 服務(wù) API 中的地理編碼拿到要定位的地理位置。

 

  1. def get_location_by_address(self, city, address): 
  2.     ""
  3.     通過地理位置到拿到經(jīng)緯度 
  4.     地理編碼:https://lbs.amap.com/api/webservice/guide/api/georegeo/ 
  5.     :param address: 
  6.     :return
  7.     ""
  8.     params = { 
  9.             'key': self.ak, 
  10.             'city': city, 
  11.             'address': address, 
  12.             'sig': self.sign 
  13.     } 
  14.  
  15.     resp = json.loads(requests.get(url=self.url_geo, params=params).text) 
  16.  
  17.     # 獲取坐標(biāo)地址 
  18.     if resp and len(resp.get('geocodes')) >= 1 and resp.get('geocodes')[0].get('location'): 
  19.          location = resp.get('geocodes')[0].get('location'
  20.          gps_data = location.split(','
  21.  
  22.          # 得到經(jīng)度和緯度 
  23.          gps_long = float(gps_data[0]) 
  24.          gps_lati = float(gps_data[1]) 
  25.  
  26.          return gps_long, gps_lati 
  27.     else
  28.          print('api解析地址出錯,請檢查ak!'
  29.          return None 

第四步,修改圖片的地理位置。

由于 piexif 中經(jīng)、緯度數(shù)據(jù)都是元組類型,因此需要將要設(shè)置的數(shù)據(jù)進(jìn)行一次處理。

 

  1. def gps_to_dms(gps_data): 
  2.     ""
  3.     坐標(biāo)轉(zhuǎn)為度、分、秒(double
  4.     116.397451 
  5.     http://www.gzhatu.com/du2dfm.html 
  6.     :param gps_data: 
  7.     :return:{1: b'N', 2: ((22, 1), (32, 1), (945, 100)), 3: b'E', 4: ((114, 1), (1, 1), (3445, 100)) 
  8.     ""
  9.     # 度:向下取整 
  10.     gps_degree = math.floor(gps_data) 
  11.  
  12.     gps_data_temp1 = (gps_data - gps_degree) * 60 
  13.  
  14.     # 分 
  15.     gps_minute = math.floor(gps_data_temp1) 
  16.  
  17.     gps_data_temp2 = gps_data_temp1 - gps_minute 
  18.  
  19.     # 秒,取小數(shù)點(diǎn)后4位 
  20.     gps_second = round(gps_data_temp2 * 60, 2) 
  21.  
  22.     # 注意:秒必須轉(zhuǎn)換為整形 
  23.     result = ((gps_degree, 1), (gps_minute, 1), (int(gps_second * 100), 100)) 
  24.  
  25.     return result 

最后,將正確格式的經(jīng)緯度數(shù)據(jù)寫入到圖片中去。

 

  1. def write_image(self, image_path, gps_long, gps_lati): 
  2.     ""
  3.     修改文件夾下所有文件的屬性 
  4.     :param image_path: 文件夾路徑 
  5.     :return
  6.     ""
  7.     # 讀取圖片 
  8.     img = Image.open(image_path) 
  9.  
  10.     try: 
  11.         exif_dict = piexif.load(img.info['exif']) 
  12.     except
  13.         print('加載文件地理位置異常!'
  14.         return 
  15.  
  16.     # 修改地理位置 
  17.     # GPS GPSLatitudeRef:N 
  18.     # GPS GPSLatitude:[22, 32, 189/20] 
  19.     # GPS GPSLongitudeRef:E 
  20.     # GPS GPSLongitude:[114, 1, 689/20] 
  21.     exif_dict['GPS'][2] = gps_to_dms(gps_lati) 
  22.     exif_dict['GPS'][4] = gps_to_dms(gps_long) 
  23.  
  24.     exif_bytes = piexif.dump(exif_dict) 
  25.  
  26.     # 寫入到新的圖片中去 
  27.     img.save(image_path, 'jpeg', exif=exif_bytes) 

3.結(jié)果結(jié)論

通過上面的 4 步操作,能將任意地理位置寫入到圖片中。

 

 

 

 

除了地理位置,圖片的元數(shù)據(jù),包含:拍攝器材、拍攝時(shí)間、拍攝參數(shù)都能進(jìn)行二次修改。

責(zé)任編輯:華軒 來源: AirPython
相關(guān)推薦

2019-08-28 16:22:30

Python數(shù)據(jù)微信

2019-10-24 09:29:04

程序員程序員節(jié)女朋友

2019-09-24 11:36:51

Python支付寶數(shù)據(jù)

2019-08-12 10:27:34

前端程序員網(wǎng)絡(luò)

2019-07-09 09:19:51

分布式事務(wù)App

2022-09-17 08:10:20

HSV飽和度圖像

2021-05-19 11:02:44

PythonTurtle參數(shù)

2021-04-06 06:23:18

MVCC并發(fā)事務(wù)

2021-05-14 07:18:07

監(jiān)控微信聊天

2020-01-02 09:14:23

Kubernetes內(nèi)部容器

2022-01-02 07:02:48

硬盤保護(hù)文件GiliSoft Fi

2021-08-11 14:33:38

注解springAutowired

2019-05-28 19:05:02

Python女朋友機(jī)器人

2014-08-21 08:59:44

2015-08-26 10:17:29

程序員女朋友

2021-02-20 07:52:35

防猝死插件 IDEA

2021-02-02 11:59:15

插件開發(fā)工具

2021-03-11 16:45:29

TCP程序C語言

2022-06-07 07:19:38

Scene 5輔助工具軟件

2020-04-21 11:45:04

技巧單一責(zé)任鏈開閉原則
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號