地理编码:将具体地址数据转换为对应坐标点经纬度功能

大致思路:

1、从数据库取得具体地理位置

2、将地址作为参数访问API接口,获取返回数据

3、处理response数据并将经度(lng、longitude)、纬度(lat、latitude)存入数据库

API接口:http://api.map.baidu.com/geocoder/v2/?address=地址(&city=城市名)&output=json&ak=ak(密钥)

address:详细地址

city:可选参数,address所在城市名,起过滤作用

output:返回数据格式,json/xml

ak:访问百度API密钥,必须有,申请很容易。EsZB0Gz6IFXqj6OGBN951ROOOdzfEXXx

数据库表设计

语言选择:python(python处理数据和访问url都比java方便简单)

import pymysql
import requests
import json
import redef getLocation():
#数据库连接
conn = pymysql.Connect(host='localhost',
port=3306,
user='root',
passwd='root',
db='AnalyseBusiness',
charset='utf8')
try:
# 获取游标
cur = conn.cursor()
# 执行sql语句 选择经纬度为空的记录
cur.execute('select * from BusinessInfo where longitude is null or latitude is null')
# 取得select返回的记录
data = cur.fetchall()
for d in data:
# url = "http://api.map.baidu.com/geocoder/v2/?address=天安门&city=北京&output=json&ak=EsZB0Gz6IFXqj6OGBN951ROOOdzfEXXx"
# 将address和city加入构成访问url get请求
url = "http://api.map.baidu.com/geocoder/v2/?address=" + d[0] + "&city=" + d[
1] + "&output=json&ak=EsZB0Gz6IFXqj6OGBN951ROOOdzfEXXx"
response = requests.get(url) ## 正则表达式获取经纬度 若查询无相关结果 取值异常 if判断list是否为空 为空设置经纬度为999作为标识
text = response.text
pattern_lng = "lng\":(.*?),"
pattern_lat = "lat\":(.*?)}"
lng = re.findall(pattern_lng, text)
lat = re.findall(pattern_lat, text)
if lng or lat:
data = (lng[0], lat[0])
else:
# 纬度:从赤道向北和向南,各分90°,北纬为正数,南纬为负数
# 经度:向东到180°或向西到180°
# 若查询不到 存入非法经纬度值 作为标识
data = ("999", "999")
sql = "update BusinessInfo set longitude='%s', latitude='%s' WHERE address='" + d[0] + "'"
cur = conn.cursor()
cur.execute(sql % data)
conn.commit()
cur.close()
conn.close()
except Exception:
conn.rollback()
conn.close()
print("定位失败")
if __name__ == '__main__':
getLocation()

结果

提示:百度Map获取到的是百度经纬度坐标,如需要转换为国测局坐标(GCJ02)的坐标系,需调用地址转换API

API接口:http://api.map.baidu.com/geoconv/v1/?coords=114.21892734521,29.575429778924&from=1&to=5&ak=密钥 //GET请求

import requests
import re
import json

def addCity():
try:
print("百度坐标")
url = "http://api.map.baidu.com/geocoder/v2/?address=大雁塔&city=陕西省西安市&output=json&ak=EsZB0Gz6IFXqj6OGBN951ROOOdzfEXXx"
response = requests.get(url)
text = response.text
print(type(text))
pattern_lng = "lng\":(.*?),"
pattern_lat = "lat\":(.*?)}"
lng = re.findall(pattern_lng, text)
lat = re.findall(pattern_lat, text)
print("lng:" + lng[0])
print("lat:" + lat[0])
print("国测局(GCJ02)坐标")
url1 = "http://api.map.baidu.com/geoconv/v1/?coords=" + lng[0] + "," + lat[
0] + "&from=3&to=5&ak=EsZB0Gz6IFXqj6OGBN951ROOOdzfEXXx"
text2 = requests.get(url1).text
pattern_x = "x\":(.*?),"
pattern_y = "y\":(.*?)}"
x = re.findall(pattern_x, text2)
y = re.findall(pattern_y, text2)
print("x:" + x[0])
print("y:" + y[0])
except Exception:
print("error") if __name__ == '__main__':
addCity()

结果

百度MapAPI之地理编码的更多相关文章

  1. 百度,google的地理编码

    1.百度的地理编码:(不支持中国以外的其它城市) http://api.map.baidu.com/geocoder/v2/?ak=E974997f80db18330f8f5c61d084a677&a ...

  2. Android百度地图开发02之添加覆盖物 + 地理编码和反地理编码

    下面来看一下地图上覆盖物的添加,以及地理编码和反地理编码. 添加覆盖物 在地图上添加覆盖物,一般需要以下几个步骤: 1. 定义坐标点,有可能是一个,有可能是多个(比如:多边形覆盖物). 2. 构造Ov ...

  3. (转载) 百度地图工具类封装(包括定位,附近、城市、范围poi检索,反地理编码)

    目录视图 摘要视图 订阅 赠书 | 异步2周年,技术图书免费选      程序员8月书讯      项目管理+代码托管+文档协作,开发更流畅 百度地图工具类封装(包括定位,附近.城市.范围poi检索, ...

  4. 在C#中通过使用Newtonsoft.Json库来解析百度地图地理编码(GeoCoder)服务接口返回的Json格式的数据

    百度地图地理编码(GeoCoder)服务接口返回的Json格式的数据,如下所示: http://api.map.baidu.com/geocoding/v3/?address=**省**市**区**路 ...

  5. 【Android】3.11 地理编码功能

    分类:C#.Android.VS2015.百度地图应用: 创建日期:2016-02-04 一.简介 地理编码指的是将地址信息建立空间坐标关系的过程,提供了地理坐标和地址之间相互转换的能力. 地理编码分 ...

  6. C#调用Geocoding API进行地理编码与逆编码

    使用C#调用Geocoding API来将地址转为经纬度,或者将经纬度转变为具体的地址. Geocoding API的详细介绍参见:http://developer.baidu.com/map/web ...

  7. 高德地图添加marker及反地理编码获取POI

    项目中集成百度.高德.腾讯地图已是司空见惯的事情,今天我总结了一下项目中用到的高德地图常用的功能: 1.展示高德地图并定位显示定位图标: 2.添加实时大头针: 3.反地理编码获取周围兴趣点 效果如下: ...

  8. 微信小程序地图之逆地理编码

    首先说一下,我微信自带map的api中并没有相关接口可调用.文中的方法建立于高德地图.(顺便吐槽,微信开发文档相比支付宝家的显得好烂!) 最近做项目用到地图定位相关的需求,为了搞定需求看了下相关的文档 ...

  9. iOS 原生地图地理编码与反地理编码

    当我们要在App实现功能:输入地名,编码为经纬度,实现导航功能. 那么,我需要用到原生地图中的地理编码功能,而在Core Location中主要包含了定位.地理编码(包括反编码)功能. 在文件中导入 ...

随机推荐

  1. P3444 [POI2006]ORK-Ploughing

    题目描述 Byteasar, the farmer, wants to plough his rectangular field. He can begin with ploughing a slic ...

  2. Jlink下载u-boot

    由于各种原因我的fl2440无启动代码,无任何程序,这时要通过jlink来烧录相关boot程序. 准备工作: 1.Jlink使用jlink commander工具 2.初始化sdram的程序boot. ...

  3. 编写clearedit的安卓控件

    1.写一个自定义的控件 public class ClearEditText extends AppCompatEditText implements View.OnFocusChangeListen ...

  4. HDU1166 敌兵布阵(树状数组实现

    敌兵布阵 Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submis ...

  5. Install the Active Directory Administration Tools on Windows Server

    安装 Active Directory 管理工具 To manage your directory from an EC2 Windows instance, you need to install ...

  6. 自己实现的JDBC工具类

    最近做了个后台应用程序,刚开始用Spring+iBatis来做的,后来因为种种原因,不让用Spring.iBatis以及一些开源的工具包.   于是用JDBC重写了原来的Service实现,项目做完了 ...

  7. windows10-seaslog安装笔记

    1.seasLog在windows下的安装 首先,要下载seasLog的dll文件,下载地址:http://pecl.php.net/package/SeasLog  选择对应你的系统和php版本的d ...

  8. 51nod 1020 逆序排列——dp

    在一个排列中,如果一对数的前后位置与大小顺序相反,即前面的数大于后面的数,那么它们就称为一个逆序.一个排列中逆序的总数就称为这个排列的逆序数. 如2 4 3 1中,2 1,4 3,4 1,3 1是逆序 ...

  9. 【Mysql优化】MySQL Profiling 的使用

    要想优化一条 Query,我们就需要清楚的知道这条 Query 的性能瓶颈到底在哪里,是消耗的 CPU计算太多,还是需要的的 IO 操作太多?要想能够清楚的了解这些信息,在 MySQL 5.0 和 M ...

  10. Linux 开机自动挂载windows分区

    blkid 查看 uuid如下ps:或者使用uuidgen <设备>查看具体设备的uuidreddusty@reddusty-X550JK:~$ sudo blkid[sudo] pass ...