ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

Python 高德API 地理编码批量转换

2021-08-16 18:01:42  阅读:268  来源: 互联网

标签:level Python gcj API key Lat Lng data 高德


地理编码:

把文字的坐标转换为经纬度

例如:XX省XX市XX区XX路XX号  转换为该地对应的经纬度

python实现

1、读取包含地址信息的原文件

import pandas as pd
data = pd.read_csv(r'文件路径\表名.csv',encoding='gbk')

读取的内容为:

 

2、利用高德API进行地理编码转换

import requests
import gcjtowgs   # 别人写的gcj转wgs的python文件

my_key_list = ['XXX','XXX']
Lng_all = []
Lat_all = []
level_all = []

for i in range(0,len(data)):
    print(i)
    if i < 3000:
        my_key = my_key_list[0]
    else:
        my_key = my_key_list[1]
        
    try:  # 防止某个文字地址没有获取到经纬度坐标信息
        address = data['注册地址'].iloc[i]
        url = 'https://restapi.amap.com/v3/geocode/geo?address='+address+'&output=json&key='+my_key+''
        html = requests.get(url)
        html.close()
        info = html.json()
        # 读取坐标(高德为火星坐标系gcj)
        Lng_gcj = info['geocodes'][0]['location'].split(',')[0]
        Lat_gcj = info['geocodes'][0]['location'].split(',')[1]
        # 将gcj火星坐标转换为wgs84坐标
        wgs = gcjtowgs.gcj02towgs84(float(Lng_gcj),float(Lat_gcj))
        Lng_all.append(wgs[0])
        Lat_all.append(wgs[1])
        # 读取level信息,以便后续判断返回的经纬度坐标数据是否准确
        level_all.append(info['geocodes'][0]['level'])
    except:
        Lng_all.append('')
        Lat_all.append('')
        level_all.append('')

3、将数据增加到原表格中

data['Lng'] = Lng_all
data['Lat'] = Lat_all
data['level'] = level_all

新表为:

4、将新表写入csv文件

data.to_csv(r'路径\新文件名.csv',index=None,encoding='gbk')

 

标签:level,Python,gcj,API,key,Lat,Lng,data,高德
来源: https://blog.csdn.net/yianxiang17hao/article/details/119736250

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有