# -*- coding: utf-8 -*-

import json

import urllib

import math

x_pi = 3.14159265358979324 * 3000.0 / 180.0

pi = 3.1415926535897932384626 # π

a = 6378245.0 # 长半轴

ee = 0.00669342162296594323 # 偏心率平方

class Geocoding:

def __init__(self, api_key):

self.api_key = api_key

def geocode(self, address):

"""

利用高德geocoding服务解析地址获取位置坐标

:param address:需要解析的地址

:return:

"""

geocoding = {'s': 'rsv3',

'key': self.api_key,

'city': '全国',

'address': address}

geocoding = urllib.urlencode(geocoding)

ret = urllib.urlopen("%s?%s" % ("http://restapi.amap.com/v3/geocode/geo", geocoding))

if ret.getcode() == 200:

res = ret.read()

json_obj = json.loads(res)

if json_obj['status'] == '1' and int(json_obj['count']) >= 1:

geocodes = json_obj['geocodes'][0]

lng = float(geocodes.get('location').split(',')[0])

lat = float(geocodes.get('location').split(',')[1])

return [lng, lat]

else:

return None

else:

return None

def gcj02_to_bd09(lng, lat):

"""

火星坐标系(GCJ-02)转百度坐标系(BD-09)

谷歌、高德——>百度

:param lng:火星坐标经度

:param lat:火星坐标纬度

:return:

"""

z = math.sqrt(lng * lng + lat * lat) + 0.00002 * math.sin(lat * x_pi)

theta = math.atan2(lat, lng) + 0.000003 * math.cos(lng * x_pi)

bd_lng = z * math.cos(theta) + 0.0065

bd_lat = z * math.sin(theta) + 0.006

return [bd_lng, bd_lat]

def bd09_to_gcj02(bd_lon, bd_lat):

"""

百度坐标系(BD-09)转火星坐标系(GCJ-02)

百度——>谷歌、高德

:param bd_lat:百度坐标纬度

:param bd_lon:百度坐标经度

:return:转换后的坐标列表形式

"""

x = bd_lon - 0.0065

y = bd_lat - 0.006

z = math.sqrt(x * x + y * y) - 0.00002 * math.sin(y * x_pi)

theta = math.atan2(y, x) - 0.000003 * math.cos(x * x_pi)

gg_lng = z * math.cos(theta)

gg_lat = z * math.sin(theta)

return [gg_lng, gg_lat]

def wgs84_to_gcj02(lng, lat):

"""

WGS84转GCJ02(火星坐标系)

:param lng:WGS84坐标系的经度

:param lat:WGS84坐标系的纬度

:return:

"""

if out_of_china(lng, lat): # 判断是否在国内

return lng, lat

dlat = _transformlat(lng - 105.0, lat - 35.0)

dlng = _transformlng(lng - 105.0, lat - 35.0)

radlat = lat / 180.0 * pi

magic = math.sin(radlat)

magic = 1 - ee * magic * magic

sqrtmagic = math.sqrt(magic)

dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)

dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)

mglat = lat + dlat

mglng = lng + dlng

return [mglng, mglat]

def gcj02_to_wgs84(lng, lat):

"""

GCJ02(火星坐标系)转GPS84

:param lng:火星坐标系的经度

:param lat:火星坐标系纬度

:return:

"""

if out_of_china(lng, lat):

return lng, lat

dlat = _transformlat(lng - 105.0, lat - 35.0)

dlng = _transformlng(lng - 105.0, lat - 35.0)

radlat = lat / 180.0 * pi

magic = math.sin(radlat)

magic = 1 - ee * magic * magic

sqrtmagic = math.sqrt(magic)

dlat = (dlat * 180.0) / ((a * (1 - ee)) / (magic * sqrtmagic) * pi)

dlng = (dlng * 180.0) / (a / sqrtmagic * math.cos(radlat) * pi)

mglat = lat + dlat

mglng = lng + dlng

return [lng * 2 - mglng, lat * 2 - mglat]

def bd09_to_wgs84(bd_lon, bd_lat):

lon, lat = bd09_to_gcj02(bd_lon, bd_lat)

return gcj02_to_wgs84(lon, lat)

def wgs84_to_bd09(lon, lat):

lon, lat = wgs84_to_gcj02(lon, lat)

return gcj02_to_bd09(lon, lat)

def _transformlat(lng, lat):

ret = -100.0 + 2.0 * lng + 3.0 * lat + 0.2 * lat * lat + \

0.1 * lng * lat + 0.2 * math.sqrt(math.fabs(lng))

ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 *

math.sin(2.0 * lng * pi)) * 2.0 / 3.0

ret += (20.0 * math.sin(lat * pi) + 40.0 *

math.sin(lat / 3.0 * pi)) * 2.0 / 3.0

ret += (160.0 * math.sin(lat / 12.0 * pi) + 320 *

math.sin(lat * pi / 30.0)) * 2.0 / 3.0

return ret

def _transformlng(lng, lat):

ret = 300.0 + lng + 2.0 * lat + 0.1 * lng * lng + \

0.1 * lng * lat + 0.1 * math.sqrt(math.fabs(lng))

ret += (20.0 * math.sin(6.0 * lng * pi) + 20.0 *

math.sin(2.0 * lng * pi)) * 2.0 / 3.0

ret += (20.0 * math.sin(lng * pi) + 40.0 *

math.sin(lng / 3.0 * pi)) * 2.0 / 3.0

ret += (150.0 * math.sin(lng / 12.0 * pi) + 300.0 *

math.sin(lng / 30.0 * pi)) * 2.0 / 3.0

return ret

def out_of_china(lng, lat):

"""

判断是否在国内,不在国内不做偏移

:param lng:

:param lat:

:return:

"""

return not (lng > 73.66 and lng < 135.05 and lat > 3.86 and lat < 53.55)

if __name__ == '__main__':

lng = 118.7294833

lat = 31.9341833

result1 = gcj02_to_bd09(lng, lat)

result2 = bd09_to_gcj02(lng, lat)

result3 = wgs84_to_gcj02(lng, lat)

result4 = gcj02_to_wgs84(lng, lat)

result5 = bd09_to_wgs84(lng, lat)

result6 = wgs84_to_bd09(lng, lat)

s,v=wgs84_to_bd09(118.7294833,31.9341833)

#lng1,lat1= wgs84_to_gcj02(lng,lat)

#s,v =gcj02_to_bd09(lng1,lat1)

print s,v

#print result1, result2, result3, result4, result5, result6

python 地图偏移_python 地图经纬度转换、纠偏相关推荐

  1. python 地图偏移_python 地图经纬度转换、纠偏的实例代码 百度地图经纬度web纠偏怎么用...

    天地图的经纬度 经过纠偏了么 给个例子证明下 如何用python实现百度地图墨卡托坐标跟经纬度坐标互转 麦哲伦机器: 系统设置 地图单位 自定义坐标系 横向墨卡托 原点纬度0 原点经度126(通化) ...

  2. python 地图偏移_python 地图经纬度转换、纠偏的实例代码

    python 地图经纬度转换.纠偏的代码如下所示: # -*- coding: utf-8 -*- import json import urllib import math x_pi = 3.141 ...

  3. python坐标轴刻度为经纬度_python各类经纬度转换

    import math import urllib import json x_pi = 3.14159265358979324 * 3000.0 / 180.0 pi = 3.14159265358 ...

  4. python字符串数组_python将字符串转换成数组的方法

    Python 这篇文章主要介绍了Python __setattr__. __getattr__. __delattr__.__call__用法示例,本文分别对这几个魔法方法做了讲解,需要的朋友可以参考 ...

  5. (百度、谷歌)地图经纬度gps偏移解决办法:gps纠偏数据库纠偏

    使用方法: 1.假设原始gps数据为(73.528888,39.368888) 2.查询数据库:SELECT * FROM offset where lng=73.52 and lat=39.36,得 ...

  6. python地图标注_Python 给定的经纬度标注在地图上的实现方法

    博主最近发现了python中一个好玩的包叫basemap,使用这个包可以绘制地图.值得说一下的是,basemap还没有pip检索,因此不能直接使用pip install basemap,来安装这个包. ...

  7. python获取某地铁站经纬度_python基于百度地图获取指定的经纬度信息

    在实际做项目的时候经常会遇上需要使用到某个位置经纬度的情况,这个位置的经纬度经常又是没有的,那么就需要基于公开的数据去获取了,这里基于百度地图提供的API来完成指定位置经纬度数据的获取,实现很简单,主 ...

  8. python获取地图上经纬度_Python从地图上划出经纬度

    我想从URL里的地图上找出经纬度 HTML脚本如下所示 '); var scope = $rootScope.$new(); scope.center = { latitude: 40.7515022 ...

  9. 谷歌地图离线发布系列之偏移处理(三)纠偏算法

    先上代码,用js实现的纠偏算法: var pi = 3.14159265358979324;// // Krasovsky 1940 // // a = 6378245.0, 1/f = 298.3 ...

最新文章

  1. Java项目:(前端vue后台java微服务)在线考试系统(java+vue+springboot+mysql+maven)
  2. 【杭电ACM】1097 A hard puzzle
  3. 2021年春季学期-信号与系统-第十次作业参考答案-第四小题
  4. php项目架构图,项目架构 · Lanson技术文档 · 看云
  5. 微型计算机内存不能用指令修改的部分,在微型计算机内存储器中,不能用指令修改其存储内容的部分是什么?...
  6. Exceptions
  7. linux 定时任务 (php)
  8. TikTok 已经成为影响力营销的新战场
  9. 如何打印出lua里table的内容
  10. DNF私服单机搭建教程
  11. java web实训任务书,课程设计任务书模板-《JavaWeb程序设计》.doc
  12. rsyslog,journalctl
  13. java 接入apple pay_支付的那些套路(apple pay篇)
  14. 北京大学计算机801考试大纲,2019年中国科学院大学801高等代数考研初试大纲
  15. 一加3T解锁OEM、刷入TWRP、第三方ROM以及ROOT
  16. 【UnityAR相关】Unity Vuforia扫图片成模型具体步骤
  17. 西北工业大学计算机学院教授张凯龙,张凯龙
  18. 服务号、订阅号、小程序、企业号(企业微信)的认知与区别
  19. paddle 图标注_基于DGCNN和概率图的轻量级信息抽取模型
  20. 成都信息工程大学计算机网络技术题库,2017年成都信息工程大学计算机学院341农业知识综合三[专业硕士]之计算机网络考研题库...

热门文章

  1. 隐藏在sketch的10个实用技巧,学会就是赚到!
  2. Linux·启动脚本·启动流程
  3. 拼接URL在线生成二维码
  4. Cocos2d-动作(Action)详解
  5. Linux修改主机名
  6. DevOps生命周期,你想知道的全都在这里了!
  7. 如何撰写综述性科技论文(网摘)
  8. 用Opencv生成一些五颜六色的图片
  9. FZU 2181 快来买肉松饼(dfs)
  10. 互联网汽车金融「退潮记」:易鑫投身腾讯,收获最佳结局