Python调用高德地图web服务API实现地址与经纬度批量转换及地图可视化操作

网上在线经纬度批量转换资源(准确度稍微有偏差):

1、经纬度在线查询,地名(批量)查询经纬度,经纬度(批量)查询地名

 

2、经纬度查询,坐标拾取工具

 

高德API官方文档地址:

地理/逆地理编码https://lbs.amap.com/api/webservice/guide/api/georegeo

坐标转换http://lbs.amap.com/api/webservice/guide/api/convert

 

调用高德地图API前,需先申请高德地图keyhttps://lbs.amap.com/

申请高德地图key详细步骤https://www.jianshu.com/p/9129a5f45c99

csv文件格式:

单条地址转经纬度:

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
"""
@author:ZSW
@file:long_lat.py
@time:2020/11/07
Python调用高德地图web服务API实现地理/逆地址编码
"""

import requests
import json


def geocode(address):
    params = {'address':address,
              'key':'你的高德密钥',
              # 'city':'上海市'
              }
    url = 'https://restapi.amap.com/v3/geocode/geo'
    res = requests.get(url, params)
    # 输出结果为json,将其转为字典格式
    result = json.loads(res.text)
    # 或者直接调用json的方法,返回python下的字典数据
    # result = res.json()
    # print(result)
    res = result['geocodes'][0]['location']
    return res


if __name__=='__main__':
    address = '上海市徐汇区'
    res = geocode(address)
    print(res)

利用高德地图api实现 地址 到 经纬度 的批量转换

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
"""
@author:ZSW
@file:batch_addr_longlat.py
@time:2020/11/09
利用高德地图api实现 地址 到 经纬度 的批量转换
"""

import requests
import pandas as pd
import json


# 读取csv文件中 organization 的列,并添加在列表中,示例['地址1','地址2',……,'地址n']
def parse_csv_addr():
    datas = []
    totalListData = pd.read_csv('test.csv')
    totalListDict = totalListData.to_dict('index')
    for i in range(0,len(totalListDict)):
        datas.append(str(totalListDict[i]['organization']))
    return datas


# 地址转经纬度 选用的是地理编码的接口
def geocode(address):
    params = {
        'address': address,
        'key': '你的高德密钥',
        'city': '上海市'
    }
    url = 'https://restapi.amap.com/v3/geocode/geo'
    data = requests.get(url, params)
    result = data.json()
    res = result['geocodes'][0]['location']
    print(res)
    return res


if __name__ == '__main__':
    i = 0
    count = 0
    df = pd.DataFrame(columns=['long_lat'])
    locations = parse_csv_addr()
    for location in locations:
        long_lat = geocode(location)
        df.loc[i] = [long_lat]
        i = i + 1
    df.to_csv('locdetail1.csv', index=False, encoding='utf-8')

利用高德地图api实现 经纬度 到 地址 的批量转换

 

#!/usr/bin/python
# -*- coding: UTF-8 -*-
"""
@author:ZSW
@file:batch_longlat_addr.py
@time:2020/11/09
利用高德地图api实现 经纬度 到 地址 的批量转换
"""

import requests
import pandas as pd

# 读取csv文件,将列longitude 和列latitude 进行拼接 并添加在列表中 示例['123.57293,32.287868',……]
def parse_csv_longlat():
    datas = []
    totalListData = pd.read_csv('test.csv')
    totalListDict = totalListData.to_dict('index')
    for i in range(0, len(totalListDict)):
        datas.append(str(totalListDict[i]['longitude']) + ',' + str(totalListDict[i]['latitude']))
    return datas


# 为了使用高德服务,用户需要将非高德坐标转换为高德坐标。
# 将用户输入的非高德坐标(GPS坐标、mapbar坐标、baidu坐标)转换成高德坐标
def transform(location):
    params = {'coordsys': 'gps', 'locations': location, 'key': '你的高德密钥'}
    url = 'http://restapi.amap.com/v3/assistant/coordinate/convert'
    result = requests.get(url, params)
    res = result.json()
    return res['locations']


# 纬度转换为地址,选用的是逆地理编码的接口
def regeocode(location):
    params = {'location': location, 'key': '你的高德密钥'}
    url = 'http://restapi.amap.com/v3/geocode/regeo'
    result = requests.get(url, params)
    res = result.json()
    return res['regeocode']['addressComponent']['district'], res['regeocode'][
        'formatted_address']


if __name__ == '__main__':
    i = 0
    count = 0
    df = pd.DataFrame(columns=['location', 'detail'])
    locations = parse_csv_longlat()
    for location in locations:
        dist, detail = regeocode(transform(location))
        df.loc[i] = [dist, detail]
        i = i + 1
    df.to_csv('locdetail.csv', index=False, encoding='utf-8')

地图可视化

登录高德开放平台后, 点击头像,即可看到 数据可视化平台,点击进去,如下:

里面有相关的案例教程:

简单实例, 经纬度坐标可视化,导入csv文件,选择需要可视化的经纬度列即可(平台中一些细节配置可以自己去尝试):

 

  • 6
    点赞
  • 57
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 6
    评论
利用Python和高德地图API实现经纬度地址批量转换是可行的。首先,我们需要准备高德地图API密钥,该密钥可以通过高德地图开发者平台申请获得。 接下来,我们可以使用Python中的requests库发送HTTP请求,通过调用高德地图的逆地理编码接口,将经纬度转换地址。我们需要将API密钥和待转换经纬度构建为合适的URL,并发送GET请求。高德地图API将返回JSON格式的数据,其中包含有关地址信息的详细内容。 在代码中,我们可以使用for循环来遍历经纬度的列表,对每个经纬度调用逆地理编码接口并解析返回的JSON数据。我们可以从返回的数据中提取出地址信息,并将其保存到一个新的CSV文件中。 以下是一个简单的示例代码: ```python import requests import csv api_key = "your_api_key" def get_address(lat, lng): url = f"https://restapi.amap.com/v3/geocode/regeo?key={api_key}&location={lng},{lat}&radius=1000&extensions=all&batch=true&roadlevel=1" response = requests.get(url) data = response.json() address = data['regeocodes'][0]['formatted_address'] return address def main(): with open('input.csv', 'r') as input_file, open('output.csv', 'w', newline='') as output_file: reader = csv.reader(input_file) writer = csv.writer(output_file) writer.writerow(['经度', '纬度', '地址']) for row in reader: lat, lng = row[0], row[1] address = get_address(lat, lng) writer.writerow([lat, lng, address]) print("地址转换完成!") if __name__ == '__main__': main() ``` 在这个示例中,我们假设输入文件是一个CSV文件,其中包含经纬度数据。我们将转换后的地址保存到新的CSV文件中,其中包含经度、纬度和地址信息。 通过运行这个Python脚本,我们可以批量转换经纬度地址,并将结果保存到输出文件中。这样,我们就可以在后续的工作中方便地使用地址信息了。
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Steven灬

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值