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

一、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的参数,网上的资料如图:

但是其中部分已经不能用了,以下给出部分仍能用的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以度为单位设置下面展示标记的代码:(为了大家更好的理解参数作用,我做了一个很难看的标记
相关攻略
新一代CSS规范带来革命性进化,原生父选择器、零权重工具、组件级响应式等特性正彻底改变样式编写方式。例如:is()、:where()、:has()及容器查询等实战技巧,能大幅精简代码、提升效率与可维护性。组合使用可减少60%-70%代码量,显著降低维护成本。
在构建响应式卡片布局时,最令人头疼的莫过于代码中散落着诸如768px、1024px这样的“魔法数字”。一旦设计稿需要调整,开发者就不得不翻遍所有相关文件进行修改,这种维护方式不仅效率低下,而且极易出错。实际上,通过充分利用SCSS强大的变量系统,我们可以将响应式逻辑进行集中化管理,实现“一处修改,全
在CSS样式表中,path[fill]选择器看似直观,但在实际应用中却存在诸多限制与细节。其能否成功匹配并控制SVG路径元素,核心取决于SVG的嵌入方式与DOM结构的呈现状态。 为何 path[fill] 选择器有时无法生效 该选择器的工作原理非常明确:它仅能匹配HTML源码中**显式定义了fill
CSS中父元素设置opacity会使子元素一同变淡,因其作用于整个渲染盒。若需背景透明而内容清晰,可使用rgba()或hsla()单独控制背景色。复杂背景可用伪元素承载并设置z-index:-1隔离。子元素发灰时,应检查祖先元素的opacity或filter属性。
大型互联网公司采用BEM作为CSS架构,因其能有效应对高复杂度项目。BEM通过block、element、modifier的命名规则,明确作用域、从属关系和状态语义,在微前端和SSR等场景中提供清晰的样式契约,实现天然隔离与稳定。它避免了嵌套选择器风险,主要价值在于大幅降低维护成本,提升团队协作效率。
热门专题
热门推荐
摘要由实在Agent通过智能技术生成。此内容由AI根据文章内容自动生成,并已由人工审核。 随着企业数字化转型进入智能体(Agent)驱动的新阶段,如何平衡AI创新与安全合规成为关键挑战。尤其在《网络安全等级保护基本要求》(等保2 0)的严格框架下,企业级智能体的部署必须同时满足效率提升与合规保障的双
使用情景 对于外贸从业者来说,年终总结绝非简单的例行汇报。它是一次至关重要的年度复盘与战略规划,既要系统梳理过去一年的业绩成果与经验得失,也要为来年的市场开拓与业务增长指明清晰路径。在全球贸易竞争白热化的今天,一份逻辑严谨、数据详实、洞察深刻的总结报告,不仅是个人专业能力的集中体现,更是赢得管理层支
使用情景 又到年末了,年度安全工作总结是每个团队都绕不开的环节。这份总结的价值,远不止于一份简单的回顾。它更像是一份“体检报告”,清晰地告诉你过去一年安全工作的“健康状况”——哪里做得好,哪里还有隐患,从而为来年的精准施策打下坚实的基础。 不过,说起写总结、做PPT,不少人就开始头疼了:内容怎么组织
Zcash (ZEC) 月度暴涨520%:深度解析后市行情与关键点位 近期,隐私币龙头Zcash (ZEC) 上演了一场令人瞩目的行情,月度涨幅高达520%,价格一度逼近300美元,创下自2021年12月以来的新高。在加密市场整体承压的背景下,ZEC的逆势狂飙吸引了全球投资者的目光。本文将结合技术分
在存量竞争的时代,电商售后数据早已超越了“成本中心”的单一角色,它正成为洞察产品质量、优化物流链路、提升用户忠诚度的核心战略资产。然而,现实往往骨感:多平台、多店铺、多套ERP系统并存,数据散落一地。靠人工手动汇总?不仅耗时费力,更关键的是,你永远无法实现真正的实时预警与敏捷响应。那么,电商售后数据





