【Python开发】Python调用高德地图web服务API实现地址批量转换经纬度

使用场景

  • 地理编码:将详细的结构化地址转换为高德经纬度坐标。且支持对地标性名胜景区、建筑物名称解析为高德经纬度坐标。
    • 结构化地址举例:北京市朝阳区阜通东大街6号转换后经纬度:116.480881,39.989410
    • 地标性建筑举例:天安门转换后经纬度:116.397499,39.908722
  • 逆地理编码:将经纬度转换为详细结构化的地址,且返回附近周边的POI、AOI信息。
    • 例如:116.480881,39.989410 转换地址描述后:北京市朝阳区阜通东大街6号

地理编码

地理编码API服务地址以及接口调用示例:
在这里插入图片描述
在这里插入图片描述

实现代码

#!/usr/bin/python
# -*- coding: UTF-8 -*-
"""
@author:Zhoooo
@file:data.py
@time:2023/7/17
Python调用高德地图web服务API实现地理/逆地址编码
"""
 
import requests
import json
import csv

 
def geocode(address):
    params = {'address':address,
              'key':'<your 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__':
    with open("file/data.csv", 'r') as f: 
        r = csv.reader(f, delimiter=',')
        for row in r:
            address = row[0]
            # 单条地址进行转换编码
            # address = "江西省宜春市袁州区官园街道锦绣大道星星充电站"
            # 多条地址进行转换编码
            res = geocode(address)
            print(res)
    

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
利用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脚本,我们可以批量转换经纬度地址,并将结果保存到输出文件中。这样,我们就可以在后续的工作中方便地使用地址信息了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值