时间:2021-05-22
中文领域:
指的是提取境内地址的经纬度,的主要调用的是百度API。中间经历了一些波折,刚开始直接使用网上代码debug半天都不行,才发现要随时跟进官方改动,使用别人的API一定要看说明书啊!
首先需要从百度地图平台上注册一个AK(在这之前要注册百度的开发者身份,免费),进入其地理编码网址:
http://lbsyun.baidu.com/index.php?title=webapi/guide/webservice-geocoding
页面:
由于我们是要从地址转换经纬度,因此看地理编码就可以了。
官网给出了服务文档(千万要看),因为爬取地址时需要提供url,这个url必须和官方提供的一致。这里需要注意两点:
1. 网上有的代码里给出的是v2,但是现在已经更新到了v3
2. 中文需要编码,使用urllib.request库里的quote默认的就行,但是可能在别的网址中会使用非大众的汉字编码方式,这个时候可以查一下相应的编码并encode一下
import jsonfrom urllib.request import urlopen, quoteimport requestsdef getlnglat(address): url = 'http://api.map.baidu.com/geocoding/v3/' output = 'json' ak = '你的AK' # 百度地图ak,具体申请自行百度,提醒需要在“控制台”-“设置”-“启动服务”-“正逆地理编码”,启动 address = quote(address) # 由于本文地址变量为中文,为防止乱码,先用quote进行编码 uri = url + '?' + 'address=' + address + '&output=' + output + '&ak=' + ak +'&callback=showLocation%20'+'//GET%E8%AF%B7%E6%B1%82'# req = urlopen(uri)# res = req.read().decode() 这种方式也可以,和下面的效果一样,都是返回json格式 res=requests.get(uri).text temp = json.loads(res) # 将字符串转化为json lat = temp['result']['location']['lat'] lng = temp['result']['location']['lng'] return lat,lng # 纬度 latitude,经度 longitude结果:
address='北京市海淀区上地十街10号'getlnglat(address)>>(40.05703033345938, 116.3084202915042)以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们都知道,可以使用高德地图api实现经纬度与地址的转换。那么,当我们有很多个地址与经纬度,需要批量转换的时候,应该怎么办呢?在这里,选用高德Web服务的API
python各类经纬度转换,具体代码如下所示:importmathimporturllibimportjsonx_pi=3.14159265358979324*
实现目的:将百度地图经纬度转换到腾讯地图/Google对应的经纬度.方法1:使用代码进行转换存在的问题:转换之后误差大,基本不可用publicstaticvoi
我们调用高德地图的API来计算经纬度#计算地址经纬度importrequestsdefgeocode(address):parameters={'address
如何利用excel将经纬度度分秒转换成小数点?利用excel的函数编辑功能可以很方便的批量将经纬度转换成十进制的小数点格式,接下来小编就给大家说说如何将经纬度度