Python 里最强的地图绘制神器


Posted in Python onMarch 01, 2021

今天给大家介绍一个非常 NB 的Python 库,专门用来绘制地图的,它叫 Folium 。

1. Folium简介

Folium是一个基于leaflet.js的Python地图库,其中,Leaflet是一个非常轻的前端地图可视化库。即可以使用Python语言调用Leaflet的地图可视化能力。它不单单可以在地图上展示数据的分布图,还可以使用Vincent/Vega在地图上加以标记。Folium可以让你用Python强大生态系统来处理数据,然后用Leaflet地图来展示。

Folium中有许多来自OpenStreetMap、MapQuest Open、MapQuestOpen Aerial、Mapbox和Stamen的内建地图元件,而且支持使用Mapbox或Cloudmade的API密钥来定制个性化的地图元件。Folium支持GeoJSON和TopoJSON两种文件格式的叠加,也可以将数据连接到这两种文件格式的叠加层,最后可使用color-brewer配色方案创建分布图。

2. Folium的使用

地图的生成

Python 里最强的地图绘制神器

img

folium.folium.Map()详解

folium.folium.Map(location=None, width='100%', height='100%', left='0%', top='0%', position='relative', tiles='OpenStreetMap', attr=None, min_zoom=0, max_zoom=18, zoom_start=10, min_lat=-90, max_lat=90, min_lon=-180, max_lon=180, max_bounds=False, crs='EPSG3857', control_scale=False, prefer_canvas=False, no_touch=False, disable_3d=False, png_enabled=False, zoom_control=True, **kwargs)

参数说明:

  • location (tuple or list, default None):纬度和经度
  • width (pixel int or percentage string (default: ‘100%')):地图宽度
  • height (pixel int or percentage string (default: ‘100%')):地图高度
  • tiles (str, default ‘OpenStreetMap') :瓦片名称或使用TileLayer classass.
  • min_zoom (int, default 0):地图可缩放的最小级别
  • max_zoom (int, default 18):地图可缩放的最大级别
  • zoom_start (int, default 10) :地图的初始缩放级别
  • attr (string, default None):当使用自定义瓦片时,传入自定义瓦片的名词
  • crs (str, default ‘EPSG3857') :投影坐标系标识
  • EPSG3857: Web墨卡托投影后的平面地图,坐标单位为米。大部分国外地图使用的时该标准。
  • EPSG4326: Web墨卡托投影后的平面地图,但仍然使用WGS84的经度、纬度表示坐标。
  • EPSG3395: 墨卡托投影,主要用于航海图
  • Simple: 简单的x,y匹配,用于自定义瓦片(比如游戏地图)
  • control_scale (bool, default False) :是否在地图上显示缩放标尺
  • prefer_canvas (bool, default False):强制使用Canvas渲染
  • no_touch (bool, default False) :是否允许触摸事件
  • disable_3d (bool, default False) :强制使用CSS 3D效果
  • zoom_control (bool, default True) :是否要限制zoom操作
  • **kwargs :Leaflets地图类的其他参数: https://leafletjs.com/reference-1.5.1.html#map
  • “tiles”参数可选值:
  • “OpenStreetMap”
  • “Mapbox Bright” (Limited levels of zoom for free tiles)
  • “Mapbox Control Room” (Limited levels of zoom for free tiles)
  • “Stamen” (Terrain, Toner, and Watercolor)
  • “Cloudmade” (Must pass API key)
  • “Mapbox” (Must pass API key)
  • “CartoDB” (positron and dark_matter)

“tiles”的自定义设置:

Python 里最强的地图绘制神器

img

地球上同一个地理位置的经纬度,在不同的坐标系中,会有少量偏移,国内目前常见的坐标系主要分为三种:

  • 地球坐标系——WGS84:常见于GPS设备,Google地图等国际标准的坐标体系。
  • 火星坐标系——GCJ-02:中国国内使用的被强制加密后的坐标体系,高德坐标就属于该种坐标体系。
  • 百度坐标系——BD-09:百度地图所使用的坐标体系,是在火星坐标系的基础上又进行了一次加密处理。

所以在设置“tiles”时需要考虑目前手中得经纬度属于那种坐标系。

由于投影坐标系中没有GCJ-02和BD-09对应的标识,所以在自定义瓦片时主要经纬度能匹配上,crs中的设置可保持不变。更多详情介绍请看:瓦片坐标系学习

如果需要将地图保存,只需执行:m.save(“map.html”) 即可。

添加点、线、面要素

添加点

import folium m = folium.Map(location=[39.917834, 116.397036], zoom_start=13, width='50%',height='50%', zoom_control='False', tiles='http://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=8&x={x}&y={y}&z={z}<ype=6',attr='AutoNavi') tooltip ='请点击我查看该点信息' folium.Marker([39.937282,116.403187], popup='南锣鼓巷',tooltip=tooltip).add_to(m) folium.Marker([39.917834,116.397036], popup='故宫',tooltip=tooltip).add_to(m) folium.Marker([39.928614,116.391746], popup='北海公园', tooltip=tooltip, icon=folium.Icon(color='red')).add_to(m) folium.Marker([39.942143,116.382590], popup='后海公园', tooltip=tooltip, icon=folium.Icon(color='green', prefix='fa', icon='taxi')).add_to(m) m

Python 里最强的地图绘制神器

img

Folium.Icon类可以设置color, icon_color, icon, angle, prefix这5个参数:

  1. color的可选项包括:[‘red', ‘blue', ‘green', ‘purple', ‘orange', ‘darkred', ‘lightred', ‘beige', ‘darkblue', ‘darkgreen', ‘cadetblue', ‘darkpurple', ‘white', ‘pink', ‘lightblue', ‘lightgreen', ‘gray', ‘black', ‘lightgray'] ,或者HTML颜色代码
  2. icon_color同上
  3. icon可以在Font-Awesome网站中找到对应的名字,并设置prefix参数为'fa'
  4. angle以度为单位设置

其他:

m.add_child(folium.LatLngPopup()) #显示鼠标点击点经纬度 m.add_child(folium.ClickForMarker(popup='Waypoint')) # 将鼠标点击点添加到地图上

添加圆

folium.Circle( radius=300, location=[39.928614,116.391746], popup='北海公园', color='crimson', fill=False, ).add_to(m) folium.CircleMarker( location=[39.942143,116.382590], radius=50, popup='后海公园', color='#3186cc', fill=True, fill_color='#3186cc' ).add_to(m)

Python 里最强的地图绘制神器

img

Circle和CircleMarker的不同:CircleMarker的radius一个单位是像素,Circle的一个单位时米

添加线段

folium.PolyLine([ [39.917834,116.397036], [39.928614,116.391746], [39.937282,116.403187], [39.942143,116.382590] ],color='red').add_to(m)

Python 里最强的地图绘制神器

添加多边形

folium.Marker([39.917834,116.397036], popup='故宫').add_to(m) folium.Marker([39.928614,116.391746], popup='北海公园').add_to(m) folium.Marker([39.937282,116.403187], popup='南锣鼓巷').add_to(m) folium.Marker([39.942143,116.382590], popup='后海公园').add_to(m) folium.Polygon([ [39.917834,116.397036], [39.928614,116.391746], [39.942143,116.382590], [39.937282,116.403187], ],color='blue', weight=2, fill=True, fill_color='blue', fill_opacity=0.3).add_to(m)

Python 里最强的地图绘制神器

Folium的其他高级应用

在地图上显示前200条犯罪数据

import folium import pandas as pd san_map = folium.Map(location=[37.77, -122.42], zoom_start=12,width='50%',height='50%') # cdata = pd.read_csv('https://cocl.us/sanfran_crime_dataset') cdata = pd.read_csv('Police_Department_Incidents_-_Previous_Year__2016_.csv') #犯罪数据,包含犯罪所在经纬度 # get the first 200 crimes in the cdata limit = 200 data = cdata.iloc[0:limit, :] # Instantiate a feature group for the incidents in the dataframe incidents = folium.map.FeatureGroup() # Loop through the 200 crimes and add each to the incidents feature group for lat, lng, in zip(cdata.Y, data.X): incidents.add_child( folium.CircleMarker( [lat, lng], radius=7, # define how big you want the circle markers to be color='yellow', fill=True, fill_color='red', fill_opacity=0.4 ) ) san_map.add_child(incidents)

Python 里最强的地图绘制神器

统计区域犯罪总数

from folium import plugins # let's start again with a clean copy of the map of San Francisco san_map = folium.Map(location=[37.77, -122.42], zoom_start=12,width='50%',height='50%') # instantiate a mark cluster object for the incidents in the dataframe incidents = plugins.MarkerCluster().add_to(san_map) # loop through the dataframe and add each data point to the mark cluster for lat, lng, label, in zip(data.Y, data.X, cdata.Category): folium.Marker( location=[lat, lng], icon=None, popup=label, ).add_to(incidents) # add incidents to map san_map.add_child(incidents)

Python 里最强的地图绘制神器

以热力图的方式呈现

from folium.plugins import HeatMap san_map = folium.Map(location=[37.77, -122.42], zoom_start=12,width='50%',height='50%') # Convert data format heatdata = data[['Y','X']].values.tolist() # add incidents to map HeatMap(heatdata).add_to(san_map) san_map

Python 里最强的地图绘制神器

在地图上呈现GeoJSON边界数据

import json import requests # url = 'https://cocl.us/sanfran_geojson' url = 'san-francisco.geojson' san_geo = f'{url}' san_map = folium.Map(location=[37.77, -122.42], zoom_start=12,width='50%',height='50%') folium.GeoJson( san_geo, style_function=lambda feature: { 'fillColor': '#ffff00', 'color': 'blue', 'weight': 2, 'dashArray': '5, 5' } ).add_to(san_map) san_map

Python 里最强的地图绘制神器

在GeoJSON上绘制Choropleth分级着色图

# Count crime numbers in each neighborhood disdata = pd.DataFrame(cdata['PdDistrict'].value_counts()) disdata.reset_index(inplace=True) disdata.rename(columns={'index':'Neighborhood','PdDistrict':'Count'},inplace=True) san_map = folium.Map(location=[37.77, -122.42], zoom_start=12,width='50%',height='50%') folium.Choropleth( geo_data=san_geo, data=disdata, columns=['Neighborhood','Count'], key_on='feature.properties.DISTRICT', #fill_color='red', fill_color='YlOrRd', fill_opacity=0.7, line_opacity=0.2, highlight=True, legend_name='Crime Counts in San Francisco' ).add_to(san_map) san_map

Python 里最强的地图绘制神器

3. 各地图提供商瓦片服务地图规则 高德地图

目前高德的瓦片地址有如下两种:

  • http://wprd0{1-4}.is.autonavi.com/appmaptile?x={x}&y={y}&z={z}&lang=zh_cn&size=1&scl=1&style=7<ype=1
  • http://webst0{1-4}.is.autonavi.com/appmaptile?style=7&x={x}&y={y}&z={z}

前者是高德的新版地址,后者是老版地址。

高德新版的参数:

  • lang:可以通过zh_cn设置中文,en设置英文
  • size:基本无作用
  • scl:瓦片尺寸控制,1=256,2=512
  • style:设置影像和路网,style=6为卫星图,style=7为街道图,style=8为标注图
  • ltype:线性控制,增加后,只对地图要素进行控制,没有文字注记,要素多少,是否透明

这些规律并不是绝对的,有可能有的组合某些参数不起作用。

谷歌地图

目前谷歌的瓦片地址也存在两种:

  • 国内:

http://mt{0-3}.google.cn/vt/lyrs=m&hl=zh-CN&gl=cn&x={x}&y={y}&z={z}

  • 国外:

http://mt{0-3}.google.com/vt/lyrs=m&hl=zh-CN&gl=cn&x={x}&y={y}&z={z}

参数详解:

  • lyrs = 类型
  • h = roads only 仅限道路
  • m = standard roadmap 标准路线图
  • p = terrain 带标签的地形图
  • r = somehow altered roadmap 某种改变的路线图
  • s = satellite only 仅限卫星
  • t = terrain only 仅限地形
  • y = hybrid 带标签的卫星图
  • gl = 坐标系
  • CN = 中国火星坐标系
  • hl = 地图文字语言
  • zh-CN = 中文
  • en-US = 英文
  • x = 瓦片横坐标
  • y = 瓦片纵坐标
  • z = 缩放级别 卫星图0-14,路线图0-17

百度地图

百度当前的瓦片地址:

  • http://online{0-4}.map.bdimg.com/onlinelabel/?qt=tile&x={x}&y={y}&z={z}&styles=pl&udt=202004151&scaler=2&p=0
  • http://api{0-3}.map.bdimg.com/customimage/tile?&x={x}&y={y}&z={z}&udt=20180601&scale=1
  • http://its.map.baidu.com:8002/traffic/TrafficTileService?level={z}&x={x}&y={y}&time=1373790856265&label=web2D&;v=017

备注:瓦片地址中的x和y对应的并不是经纬度值,而是瓦片编号,中国主要地图商的瓦片编号流派:

Python 里最强的地图绘制神器

目前百度的瓦片编号比较特殊,Folium暂不支持。

其他参考资料:

  • https://github.com/geometalab/pyGeoTile
  • https://github.com/anzhihun/OpenLayers3Primer/blob/master/ch05/05-03.md
  • http://www.winseliu.com/blog/2018/01/30/map-started-guide/
  • https://github.com/CntChen/tile-lnglat-transform

腾讯地图

腾讯地图的瓦片地图URL格式:

  • http://rt1.map.gtimg.com/realtimerender?z={z}&x={x}&y={y}&type=vector&style=0

由于腾讯地图使用的瓦片编码时TMS,所以使用时需要额外的设置。具体如下:

Python 里最强的地图绘制神器

其他底图

Python 里最强的地图绘制神器

  • {0,1,2,3}代表了url的subDomain,在请求时会随机的在url中使用mt0、mt1、mt2、mt3。{z}代表zoom,即缩放级别,{x}代表列号,{y}代表行号。
  • GeoQ 官网有公开的多个基于 ArcGIS 的地图服务,均可使用,详见

https://map.geoq.cn/arcgis/rest/services

到此这篇关于Python 里最强的地图绘制神器的文章就介绍到这了,更多相关Python地图绘制神器内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章希望大家以后多多支持三水点靠木!

Python 相关文章推荐
Python yield 小结和实例
Apr 25 Python
详解Python3.1版本带来的核心变化
Apr 07 Python
python黑魔法之编码转换
Jan 25 Python
python 容器总结整理
Apr 04 Python
Python实现一个服务器监听多个客户端请求
Apr 12 Python
Python从ZabbixAPI获取信息及实现Zabbix-API 监控的方法
Sep 17 Python
3个用于数据科学的顶级Python库
Sep 29 Python
Python面向对象程序设计类变量与成员变量、类方法与成员方法用法分析
Apr 12 Python
python3中利用filter函数输出小于某个数的所有回文数实例
Nov 24 Python
pytorch加载自己的图像数据集实例
Jul 07 Python
python 图像增强算法实现详解
Jan 24 Python
Python基于百度API识别并提取图片中文字
Jun 27 Python
Python的collections模块真的很好用
Mar 01 #Python
Python  Asyncio模块实现的生产消费者模型的方法
Mar 01 #Python
Python创建自己的加密货币的示例
Mar 01 #Python
python 实现网易邮箱邮件阅读和删除的辅助小脚本
Mar 01 #Python
详解Django中的FBV和CBV对比分析
Mar 01 #Python
Python3压缩和解压缩实现代码
Mar 01 #Python
python re模块常见用法例举
Mar 01 #Python
You might like
MySQL中create table语句的基本语法是
2007/01/15 PHP
几种有用的变型 PHP中循环语句的用法介绍
2012/01/30 PHP
CI框架中libraries,helpers,hooks文件夹详细说明
2014/06/10 PHP
PHP中CheckBox多选框上传失败的代码写法
2017/02/13 PHP
PHP全局使用Laravel辅助函数dd
2019/12/26 PHP
页面中iframe相互传值传参
2009/12/13 Javascript
HTTP 304错误的详细讲解
2013/11/13 Javascript
javascript实现选中复选框后相关输入框变灰不可用的方法
2015/08/11 Javascript
jQuery实现带滑动条的菜单效果代码
2015/08/26 Javascript
jQuery zclip插件实现跨浏览器复制功能
2015/11/02 Javascript
javascript新闻跑马灯实例代码
2020/07/29 Javascript
javascript回到顶部特效
2016/07/30 Javascript
Javascript之面向对象--封装
2016/12/02 Javascript
vue.js+Element实现表格里的增删改查
2017/01/18 Javascript
jQuery树控件zTree使用方法详解(一)
2017/02/28 Javascript
JS中IP地址与整数相互转换的实现代码
2017/04/10 Javascript
ES6中数组array新增方法实例总结
2017/11/07 Javascript
浅谈Vue网络请求之interceptors实际应用
2018/02/28 Javascript
Vue路由切换时的左滑和右滑效果示例
2018/05/29 Javascript
vue 实现左右拖拽元素并且不超过他的父元素的宽度
2018/11/30 Javascript
小程序自定义单页面、全局导航栏的实现代码
2019/03/15 Javascript
实例详解带参数的 npm script
2019/05/28 Javascript
javascript实现动态时钟的启动和停止
2020/07/29 Javascript
JS将指定的某个字符全部转换为其他字符实例代码
2020/10/13 Javascript
提升Python程序运行效率的6个方法
2015/03/31 Python
使用pdb模块调试Python程序实例
2015/06/02 Python
Python脚本实时处理log文件的方法
2016/11/21 Python
对Django 转发和重定向的实例详解
2019/08/06 Python
jupyter 中文乱码设置编码格式 避免控制台输出的解决
2020/04/20 Python
pymysql之cur.fetchall() 和cur.fetchone()用法详解
2020/05/15 Python
使用python实现时间序列白噪声检验方式
2020/06/03 Python
给Django Admin添加验证码和多次登录尝试限制的实现
2020/07/26 Python
机关职员工作检讨书
2014/10/23 职场文书
大学考试作弊检讨书
2015/05/06 职场文书
php引用传递
2021/04/01 PHP
Python自动化实战之接口请求的实现
2022/05/30 Python