- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Python绘制地图神器folium的新人入门指南由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
想通过 Python 绘制精美的地图?想在地图上自由的设置各种参数?想获得灵活的交互体验?这里就有一款Python 神包满足你:folium.
folium 建立在 Python 生态系统的数据应用能力和 Leaflet.js 库的映射能力之上,在Python中操作数据,然后通过 folium 在 Leaflet 地图中可视化.
folium 相比较于国内百度的 pyecharts 灵活性更强,能够自定义绘制区域,并且展现形式更加多样化.
附:官方文档,官方示例,本文 notebook ,完整代码及数据.
按照官方的教程即可,如果安装了 conda ,可以直接 。
conda install -c conda-forge folium
没有安装的话就使用 。
python3 -m pip install folium
folium 显示地图的类为 folium.Map,类的声明如下 。
class 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 经纬度,list 或者 tuple 格式,顺序为 latitude, longitude zoom_start 缩放值,默认为 10,值越大比例尺越小,地图放大级别越大 tiles 显示样式,默认*‘OpenStreetMap'*,也就是开启街道显示 crs 地理坐标参考系统,默认为"EPSG3857"import foliumprint(folium.__version__)# define the world mapworld_map = folium.Map()# display world mapworld_map
# define the national mapnational_map = folium.Map(location=[35.3, 100.6], zoom_start=4)# display national mapnational_map
其实改变地图显示就是改变显示的经纬度和缩放比例,省级、市级、县级用法雷同,这里举一个市级的例子为例,如北京市:
# define the city mapcity_map = folium.Map(location=[39.93, 116.40], zoom_start=10)# display city mapcity_map
显示效果确实是不如百度的.
除了上述正常的地图显示外,folium 还提供了非常丰富的多样化显示,控制显示效果的变量是tiles,样式有OpenStreetMap, Stamen Terrain, Stamen Toner, Mapbox Bright, Mapbox Control Room等等,这里挑选几个比较常见的 。
# define the city map,tiles='Stamen Toner'city_map = folium.Map(location=[39.93, 116.40], zoom_start=10, tiles='Stamen Toner')# display city mapcity_map
# define the city map, tiles='Stamen Terrain'city_map = folium.Map(location=[39.93, 116.40], zoom_start=10, tiles='Stamen Terrain')# display city mapcity_map
添加普通标记用 Marker 。
这里可以选择标记的图案.
bj_map = folium.Map(location=[39.93, 115.40], zoom_start=12, tiles='Stamen Terrain')folium.Marker( location=[39.95, 115.33], popup='Mt. Hood Meadows', icon=folium.Icon(icon='cloud')).add_to(bj_map)folium.Marker( location=[39.96, 115.32], popup='Timberline Lodge', icon=folium.Icon(color='green')).add_to(bj_map)folium.Marker( location=[39.93, 115.34], popup='Some Other Location', icon=folium.Icon(color='red', icon='info-sign')).add_to(bj_map)bj_map
添加圆形标记用 Circle 以及 CircleMarker 。
bj_map = folium.Map(location=[39.93, 116.40], zoom_start=12, tiles='Stamen Toner')folium.Circle( radius=200, location=[39.92, 116.43], popup='The Waterfront', color='crimson', fill=False,).add_to(bj_map)folium.CircleMarker( location=[39.93, 116.38], radius=50, popup='Laurelhurst Park', color='#3186cc', fill=True, fill_color='#3186cc').add_to(bj_map)bj_map
m = folium.Map(location=[46.1991, -122.1889],tiles='Stamen Terrain',zoom_start=13)m.add_child(folium.LatLngPopup())m
通过点击鼠标便可以获取点击出的经纬度.
m = folium.Map( location=[46.8527, -121.7649], tiles='Stamen Terrain', zoom_start=13)folium.Marker( [46.8354, -121.7325], popup='Camp Muir').add_to(m)m.add_child(folium.ClickForMarker(popup='Waypoint'))m
因为没有实际的经纬度坐标数据,所以这里只能模拟一些位置出来,另外每个位置还需要一个数值作为热力值.
# generated dataimport numpy as npdata = ( np.random.normal(size=(100, 3)) * np.array([[0.1, 0.1, 0.1]]) + np.array([[40, 116.5, 1]])).tolist()data[:3]
数据分布 。
[[40.04666663299843, 116.59569796477264, 0.9667425547098781], [39.86836537517533, 116.28201445195315, 0.8708549157348728], [40.08123232852134, 116.56884585184197, 0.9104952244371285]]
绘制热力图 。
# HeatMapfrom folium.plugins import HeatMapm = folium.Map([39.93, 116.38], tiles='stamentoner', zoom_start=6)HeatMap(data).add_to(m)# m.save(os.path.join('results', 'Heatmap.html'))m
folium 不仅可以绘制热力图,还可以绘制密度地图,按照经纬度进行举例聚类,然后在地图中显示.
from folium.plugins import MarkerClusterm = folium.Map([39.93, 116.38], tiles='stamentoner', zoom_start=10)# create a mark cluster objectmarker_cluster = MarkerCluster().add_to(m)# add data point to the mark clusterfor lat, lng, label in data: folium.Marker( location=[lat, lng], icon=None, popup=label, ).add_to(marker_cluster)# add marker_cluster to mapm.add_child(marker_cluster)
folium 一个非常有优势的功能就是自定义区域的绘制了,只要有区域的边界数据,就可以在地图中以多种多样的形式展现出来,这里以 folium 官方的美国地图为例,源数据是一个 .json 文件,里面包含了各个地区(美国各州)的特征(包括边界经纬度列表、简称等),源数据传送门,其数据格式如下:
如果只要求绘制边界,而不显示边界区域的相关信息,那么这个是比较容易的,代码如下 。
import jsonimport requests# read us-states border with open("us-states.json") as f: us_states = json.load(f)us_map = folium.Map(location=[35.3, -97.6], zoom_start=4)folium.GeoJson( us_states, style_function=lambda feature: { 'fillColor': '#ffff00', 'color': 'black', 'weight': 2, 'dashArray': '5, 5' }).add_to(us_map)#display mapus_map
当需要在各个区域填充数据的时候,这个稍微麻烦点,不仅需要各个区域的边界数据,还需要各个区域的显示信息,这里同样也使用官方的美国各州的边界数据为例:
import geopandas as gpdimport pandas as pdimport folium, brancastates = gpd.GeoDataFrame.from_features(us_states, crs=fiona.crs.from_epsg(4326))states.head()
我们再把收入等数据连接到上表中 。
abbrs = pd.read_json(open("abbrs.json"))statesmerge = states.merge(abbrs,how='left', left_on='name', right_on='name')statesmerge['geometry']=statesmerge.geometry.simplify(.05)income = pd.read_csv("income.csv", dtype={"fips":str})income['income-2015']=pd.to_numeric(income['income-2015'], errors='coerce')income.groupby(by="state")[['state','income-2015']].median().head()statesmerge['medianincome']=statesmerge.merge(income.groupby(by="state")[['state','income-2015']].median(), how='left', left_on='alpha-2', right_on='state')['income-2015']statesmerge['change']=statesmerge.merge(income.groupby(by="state")[['state','change']].median(), how='left', left_on='alpha-2', right_on='state')['change']statesmerge.head()
最终绘制出的来的地图如下:
除此之外,还有很多非常有趣的功能,这里就不一一列举了,感兴趣的可以参考官方的文档.
国内的竞品为百度的 pyecharts,和 folium 一样都可以实现普通的地图绘制功能,但是具体使用还有较大的区别,具体如下表 。
功能 | pyecharts | folium | 备注 |
---|---|---|---|
世界地图 | 可以 | 可以 | |
中文显示 | 可以 | 部分可以 | folium地图中标尺、文字不能正常显示,但是嵌入地图中的中文可以正常显示 |
交互性 | 好 | 好 | |
区(县)级地图 | 可以 | 可以 | folium需要区(县)边界数据 |
市级地图 | 可以 | 可以 | folium需要市边界数据 |
收费 | 自定义区域需要购买百度ak | 自定义区域功能免费 | |
灵活性 | 好 | 好 | |
省级地图 | 可以 | 可以 | folium需要省边界数据 |
美观度 | 好 | 较好 | |
自定义区域 | 部分可以 | 可以 | pyecharts需要百度 ak,folium免费 |
[1] https://www.zhihu.com/question/33783546 。
[2] https://pypi.org/project/folium/ 。
[3] https://nbviewer.jupyter.org/github/python-visualization/folium/tree/master/examples/ 。
到此这篇关于Python绘制地图神器folium的文章就介绍到这了,更多相关Python绘制地图folium内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持我! 。
原文链接:https://blog.csdn.net/weixin_38169413/article/details/104806257 。
最后此篇关于Python绘制地图神器folium的新人入门指南的文章就讲到这里了,如果你想了解更多关于Python绘制地图神器folium的新人入门指南的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个库项目,在 Android Studio 1.3.0 上开发并部署到 Artifactory Open Source Local Repository (3.5) 但是当我尝试在应用程序项目中
logging 是 python 标准模块,用于记录和处理程序中的日志。 功能很强大,官方文档很详细,网上也有大量的说明和教程,但是对很多初次接触的同学来说,存在一些障碍。 一是因为标准库文
我正在尝试使用 Maven 生成用于在 Vignette Portal 上部署的工件。包装与war完全一样工件但文件应该有 car取而代之。 我尝试过但无法完成的选项。 使用 war 插件并重命名最终
为什么 Points AdditiveBlending 只在从右看而不是从左看时有效?设置 depthTest:false 会解决问题,但会引发另一个问题,即点覆盖其他网格。 My fir
我对 UITextField 在动画 block 中移动时出现的工件有疑问... 在我移动我的 UITextField 之前它看起来像这样: 像这样移动之后: 我的猜测是它与 UITextField
单击此导航菜单中的第一个下拉菜单后,它将按预期加下划线,一旦菜单失去焦点(即单击页面上的其他位置),标签末尾的下划线不会被删除。 仅在 Chrome(版本 45.0.2454.85 m)中发生 我希望
我有一个简单的“hello world”C++ 项目:https://github.com/RomainGoussault/Deepov 我使用 Eclipse IDE for C/C++ Devel
使用方法有两种,可以用 XShell 或 Putty 上去命令查看,也可以生成 html 报告。 下面介绍GoAccess 在 CentOS 上的安装方法: 1. 需要安装 GeoIP, ncu
我一整天都在尝试将我的 javafx 应用程序转换为 jar 文件。我正在使用 Java 1.7 更新 7。 Oracle 有 some information ,但它似乎散落在各处。 Intelli
我实际上希望通过项目中的传递依赖项获得 powermock 1.5.6 版,但我只得到 1.4.11。这是什么意思? 最佳答案 在解析依赖项时,Maven 将更喜欢 POM 部分中指定的版本,而不是从
是否有公开可用的 maven 存储库将 Apache Tomcat 二进制分发 ZIP 托管为 maven Artifact (我的意思是可以通过 http://tomcat.apache.org 下
我希望在单击时播放 mp4 工件文件。 但是,当我点击mp4工件文件时,它看起来像下图。它不播放 如果我下载它然后我可以在我的本地 PC 上播放它。 所以我尝试了 HTML5 嵌入功能来流式传输它。我
我在 VSTS 上设置了构建/测试/发布。我们还有另一个管道(在 Linux 中)从具有给定构建 ID 的构建系统中获取构建工件。那么有没有办法从 Linux 上的 VSTS 下载构建工件?我发现不登
用 Ventoy 创建多启动 U 盘,你将永远不会缺少自己喜欢的 Linux 发行版。 给朋友和邻居一个可启动 U 盘,里面包含你最喜欢的 Linux 发行版,是向 Linux 新手介绍我们都
API 管理工具可以说是每个前端/后端开发必备的工具了,一个好的 API 管理工具可以提高团队的工作效率。 目前市面上有不少 API 相关的工具,比如 Postman、swagger 等。最近我也尝试
我有一个关于 JFrog Artifactory 用于在 Artifact 中查找“事物”的 AQL( Artifact 查询语言)的问题。 AQL 似乎非常强大,但我想知道如何使用正确的术语构建(正
我正在使用 Maven 3.1.1、Java 6 和 JBoss 7.1.3。我想在我的 JSP 上将对象呈现为 JSON,但是当我将其包含在我的 pom 中时
每次我对 POM 进行最微小的更改时,Intellij 都会删除项目结构输出目录设置中分解 Artifact 的 .war 扩展名。这会导致 Intellij 的运行/调试配置出错: Artifact
我的目标是进行对象跟踪。 我有一个 UWP c# 应用程序和链接的 c++ windows 运行时组件。在那里我可以获得对 opencv 的访问权限。 在 c# 中,MediaCapture 返回 S
遵循 http://doc.gitlab.com/ee/ci/yaml/README.html 的文档设置文件 .yml 我通过创建 artifacts 发现了问题,当构建要下载此 ZIPAPK 文件
我是一名优秀的程序员,十分优秀!