什么是百度Geocoding API?
Geocoding API是一个供程序员调用的、http形式的地图服务接口。主要服务那些非网页程序的调用。例如C# 、C++、Java等开发语言都能发送http请求且能接收返回数据。
用户只需在请求的url字串中拼接好关键字或者经纬度信息,即可获取到相应的百度经纬度或者结构化地理信息。
Geocoding API有哪些功能?
Geocoding API包括地址解析和逆地址解析功能。
地址解析是指,由详细到街道的结构化地址得到百度经纬度信息,且支持名胜古迹、标志性建筑名称直接解析返回百度经纬度。例如:“北京市海淀区中关村南大街27号”地址解析的结果是“lng:116.31985,lat:39.959836”,“百度大厦”地址解析的结果是“lng:116.30815,lat:40.056885”
逆地址解析是指,由百度经纬度信息得到结构化地址信息。例如:“lat:31.325152,lng:120.558957”逆地址解析的结果是“江苏省苏州市虎丘区塔园路318号”。
注意:
1.因为Geocoding和反Geocoding使用的门址数据以及算法都不是一样的,所以会出现不能一一对应的现象。
2.解析过程中可能会出现一对坐标值对应多个地址门牌信息,本接口将返回距离坐标点最近的一个地址门牌信息。
问题
最近一个项目,需要根据数据库的地址列转为经纬度信息,对比了geopy和百度的Geocoding API后,基于简单快捷的考虑,决定直接使用百度的API。
代码实现
地址解析为经纬度
import
返回,
{
经纬度反向解析为地址,
lng_lat
返回,
{
封装成Python函数
import
测试下
geocoding("杭州临安汽车东站")
#返回 119.738708,30.236846
碰到地址无法解析,会返回116.413384,39.910925
geocoding("hello")
#返回116.413384,39.910925
经反向解析为,
{
注册为SQLite UDF
from
ipython-sql下如何注册UDF?
%load_ext sql
%sql sqlite://
conns=%sql -l
print(conns)
connection=conns['sqlite://'].session.connection.connection
connection.create_function('geocoding', 1, geocoding)
%sql select geocoding('杭州临安汽车东站')
参考
- http://api.map.baidu.com/lbsapi/cloud/geocoding-api.htm
https://github.com/catherinedevlin/ipython-sql
把百度地图Geocoding API封装成UDFmp.weixin.qq.com