首页 游戏 软件 资讯 排行榜 专题
首页
AI资讯
【Python库】地图可视化库folium学习笔记(一)

【Python库】地图可视化库folium学习笔记(一)

热心网友
35
转载
2025-07-25
本文介绍了Folium,它是基于Leaflet.js的Python地图可视化API。内容涵盖环境准备,即安装和导入库;地图框架构建,包括Map类参数详解、坐标系差异及地图样式更改;还讲解了地图标记方法,如点、动态点、圆、线、多边形标记的参数与用法,可帮助用户实现地理数据可视化。

【python库】地图可视化库folium学习笔记(一) - 游乐网

一、Folium简介

Folium是Leaflet.js为Python提供的API,即可以使用Python语言调用Leaflet的地图可视化能力。

其中,Leaflet是一个地理信息可视化库。

二、基础介绍和实践

(一)、环境准备

In [2]

# 安装folium库 !pip install folium
登录后复制

In [3]

立即学习“Python免费学习笔记(深入)”;

# 导入folium库 import folium print(folium.__version__)
登录后复制
0.12.1
登录后复制

(二)地图框架构建

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 (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地图类的其他参数

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

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

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

由于投影坐标系中没有GCJ-02和BD-09对应的标识,所以在自定义瓦片时主要经纬度能匹配上,crs中的设置可保持不变

In [4]

import folium import os '''创建Map对象''' m = folium.Map(location=[39.923697,119.552191],               width='100%', height='100%',                zoom_start=14) '''查看m的类型''' m.__class__
登录后复制
folium.folium.Map
登录后复制

In [6]

m
登录后复制
登录后复制

In [7]

# 保存地图 m.save('map.html')
登录后复制

获取各级地图

通过调整zoom_start得到不同比例的地图,关于获取地图的经纬度可通过百度地图拾取坐标系统。

In [118]

# define the national map national_map = folium.Map(location=[35.3, 100.6], zoom_start=4) # display national map national_map
登录后复制
登录后复制

In [119]

# define the city map city_map = folium.Map(location=[39.93, 116.40], zoom_start=10) # display city map city_map
登录后复制
登录后复制

大家可以根据自己的需求在上面的代码中调整经纬度location和初始缩放系数zoom_start获取自己想要的地图

更改地图样式

下面我们通过改变tiles的参数给地图换样式

关于tiles的参数,网上的资料如图:

【Python库】地图可视化库folium学习笔记(一) - 游乐网

但是其中部分已经不能用了,以下给出部分仍能用的tiles参数:

titles=

'Stamen Terrain''Stamen Toner''Stamen Watercolor'

以下为自定义的tiles参数,也可以用:

高德底图

街道图 :'https://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=7&x={x}&y={y}&z={z}'卫星图:'https://webst02.is.autonavi.com/appmaptile?style=6&x={x}&y={y}&z={z}'

更多底图获取可以点击链接:底图合集,里面的格式与高德的底图相似。

注:自定义地图底图需要修改attr参数,为瓦片的名字,嫌麻烦也可以随便写(不推荐。

最后给出部分不同地图样式的代码:

In [120]

#默认地图样式 m = folium.Map(location=[39.923697,119.552191],               zoom_start=14,tiles='OpenStreetMap',               attr="Transport") m
登录后复制
登录后复制

In [121]

m = folium.Map(location=[39.923697,119.552191],               zoom_start=14,tiles='Stamen Toner') m
登录后复制
登录后复制

In [122]

# 高德街道图,自定义的样式需修改attr参数 m = folium.Map(location=[39.923697,119.552191],               zoom_start=14,tiles='https://webrd02.is.autonavi.com/appmaptile?lang=zh_cn&size=1&scale=1&style=7&x={x}&y={y}&z={z}',               attr="a"               ) m
登录后复制
登录后复制

(三)地图标记

获取经纬度

在下面代码生成的地图上点击即可出现经纬度坐标

In [123]

m = folium.Map(location=[46.1991, -122.1889],tiles='Stamen Terrain',zoom_start=13) m.add_child(folium.LatLngPopup()) m
登录后复制
登录后复制

点标记

folium.folium.Marker()常见参数介绍

location:经纬度坐标(纬度在前)popup:标记点名称tooltip:标记点提示信息Folium.Icon类可以设置color, icon_color, icon, angle, prefix这5个参数:color的可选项包括:[‘red’, ‘blue’, ‘green’, ‘purple’, ‘orange’, ‘darkred’, ‘lightred’, ‘beige’, ‘darkblue’, ‘darkgreen’, ‘cadetblue’, ‘darkpurple’, ‘white’, ‘pink’, ‘lightblue’, ‘lightgreen’, ‘gray’, ‘black’, ‘lightgray’] ,或者HTML颜色代码icon_color同上icon可以在Font-Awesome 中找到对应的名字,并设置prefix参数为’fa’(其实这个prefix好像默认就是’fa‘)angle以度为单位设置

下面展示标记的代码:(为了大家更好的理解参数作用,我做了一个很难看的标记

来源:https://www.php.cn/faq/1426835.html
免责声明: 游乐网为非赢利性网站,所展示的游戏/软件/文章内容均来自于互联网或第三方用户上传分享,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系youleyoucom@outlook.com。

相关攻略

2026年现代CSS实战技巧14个高效方法大幅减少代码量
业界动态
2026年现代CSS实战技巧14个高效方法大幅减少代码量

新一代CSS规范带来革命性进化,原生父选择器、零权重工具、组件级响应式等特性正彻底改变样式编写方式。例如:is()、:where()、:has()及容器查询等实战技巧,能大幅精简代码、提升效率与可维护性。组合使用可减少60%-70%代码量,显著降低维护成本。

热心网友
05.13
SCSS响应式卡片布局实战教程栅格系统与变量应用详解
前端开发
SCSS响应式卡片布局实战教程栅格系统与变量应用详解

在构建响应式卡片布局时,最令人头疼的莫过于代码中散落着诸如768px、1024px这样的“魔法数字”。一旦设计稿需要调整,开发者就不得不翻遍所有相关文件进行修改,这种维护方式不仅效率低下,而且极易出错。实际上,通过充分利用SCSS强大的变量系统,我们可以将响应式逻辑进行集中化管理,实现“一处修改,全

热心网友
05.11
CSS选择器控制SVG路径颜色详解 path[fill]属性应用指南
前端开发
CSS选择器控制SVG路径颜色详解 path[fill]属性应用指南

在CSS样式表中,path[fill]选择器看似直观,但在实际应用中却存在诸多限制与细节。其能否成功匹配并控制SVG路径元素,核心取决于SVG的嵌入方式与DOM结构的呈现状态。 为何 path[fill] 选择器有时无法生效 该选择器的工作原理非常明确:它仅能匹配HTML源码中**显式定义了fill

热心网友
05.11
CSS盒子透明度影响子元素如何用rgba背景替代opacity解决
前端开发
CSS盒子透明度影响子元素如何用rgba背景替代opacity解决

CSS中父元素设置opacity会使子元素一同变淡,因其作用于整个渲染盒。若需背景透明而内容清晰,可使用rgba()或hsla()单独控制背景色。复杂背景可用伪元素承载并设置z-index:-1隔离。子元素发灰时,应检查祖先元素的opacity或filter属性。

热心网友
05.11
大型互联网公司为何选择BEM架构分析CSS扩展性与稳定性
前端开发
大型互联网公司为何选择BEM架构分析CSS扩展性与稳定性

大型互联网公司采用BEM作为CSS架构,因其能有效应对高复杂度项目。BEM通过block、element、modifier的命名规则,明确作用域、从属关系和状态语义,在微前端和SSR等场景中提供清晰的样式契约,实现天然隔离与稳定。它避免了嵌套选择器风险,主要价值在于大幅降低维护成本,提升团队协作效率。

热心网友
05.11

最新APP

宝宝过生日
宝宝过生日
应用辅助 04-07
台球世界
台球世界
体育竞技 04-07
解绳子
解绳子
休闲益智 04-07
骑兵冲突
骑兵冲突
棋牌策略 04-07
三国真龙传
三国真龙传
角色扮演 04-07

热门推荐

企业网络安全等级保护合规指南:龙虾养殖业如何落地实施
AI资讯
企业网络安全等级保护合规指南:龙虾养殖业如何落地实施

摘要由实在Agent通过智能技术生成。此内容由AI根据文章内容自动生成,并已由人工审核。 随着企业数字化转型进入智能体(Agent)驱动的新阶段,如何平衡AI创新与安全合规成为关键挑战。尤其在《网络安全等级保护基本要求》(等保2 0)的严格框架下,企业级智能体的部署必须同时满足效率提升与合规保障的双

热心网友
05.23
外贸业务员年终总结PPT制作指南 AI高效提升总结效果
AI教程
外贸业务员年终总结PPT制作指南 AI高效提升总结效果

使用情景 对于外贸从业者来说,年终总结绝非简单的例行汇报。它是一次至关重要的年度复盘与战略规划,既要系统梳理过去一年的业绩成果与经验得失,也要为来年的市场开拓与业务增长指明清晰路径。在全球贸易竞争白热化的今天,一份逻辑严谨、数据详实、洞察深刻的总结报告,不仅是个人专业能力的集中体现,更是赢得管理层支

热心网友
05.23
WPS AI一键生成年度安全工作总结PPT高效制作专业汇报
AI教程
WPS AI一键生成年度安全工作总结PPT高效制作专业汇报

使用情景 又到年末了,年度安全工作总结是每个团队都绕不开的环节。这份总结的价值,远不止于一份简单的回顾。它更像是一份“体检报告”,清晰地告诉你过去一年安全工作的“健康状况”——哪里做得好,哪里还有隐患,从而为来年的精准施策打下坚实的基础。 不过,说起写总结、做PPT,不少人就开始头疼了:内容怎么组织

热心网友
05.23
ZEC价格暴涨520%后还能买吗 深度解析Zcash未来走势与投资潜力
web3.0
ZEC价格暴涨520%后还能买吗 深度解析Zcash未来走势与投资潜力

Zcash (ZEC) 月度暴涨520%:深度解析后市行情与关键点位 近期,隐私币龙头Zcash (ZEC) 上演了一场令人瞩目的行情,月度涨幅高达520%,价格一度逼近300美元,创下自2021年12月以来的新高。在加密市场整体承压的背景下,ZEC的逆势狂飙吸引了全球投资者的目光。本文将结合技术分

热心网友
05.23
电商售后数据自动汇总分析流程与智能化方案详解
AI资讯
电商售后数据自动汇总分析流程与智能化方案详解

在存量竞争的时代,电商售后数据早已超越了“成本中心”的单一角色,它正成为洞察产品质量、优化物流链路、提升用户忠诚度的核心战略资产。然而,现实往往骨感:多平台、多店铺、多套ERP系统并存,数据散落一地。靠人工手动汇总?不仅耗时费力,更关键的是,你永远无法实现真正的实时预警与敏捷响应。那么,电商售后数据

热心网友
05.23