0

0

Folium地图集成交互式图表教程

聖光之護

聖光之護

发布时间:2025-12-03 12:20:02

|

692人浏览过

|

来源于php中文网

原创

Folium地图集成交互式图表教程

本教程详细介绍了如何在folium地图中集成交互式图表。通过结合python的folium库、matplotlib进行图表绘制,并利用mpld3库将图表转换为可交互的html内容,最终将其嵌入到folium地图的标记弹出窗口中。文章将指导您完成环境搭建、图表创建、html转换及地图集成的完整流程,助您构建功能丰富的地理数据可视化应用。

1. 引言

在地理信息可视化中,将数据图表与地图相结合能够显著提升数据的洞察力和交互性。Folium作为一个强大的Python库,能够方便地创建Leaflet地图,但其本身并不直接提供在地图上绘制复杂图表的功能。本教程将介绍一种有效的方法,通过集成Matplotlib等图表库,并借助mpld3库将生成的图表转换为交互式HTML,最终将其作为弹出内容(Popup)添加到Folium地图的标记(Marker)上,从而实现地图与图表的动态结合。

2. 环境准备与库安装

在开始之前,请确保您的Python环境中已安装必要的库。您可以通过以下命令进行安装:

pip install folium matplotlib mpld3
  • folium: 用于创建和操作Leaflet地图。
  • matplotlib: 用于生成各种类型的静态图表。
  • mpld3: 用于将Matplotlib图表转换为可交互的D3.js驱动的HTML。

3. 初始化Folium地图

首先,我们需要创建一个Folium地图对象作为我们操作的基础。您可以指定地图的中心坐标和初始缩放级别。

import folium

# 定义地图中心坐标(例如:北京)
latitude, longitude = 39.9042, 116.4074
zoom_start = 12

# 创建Folium地图对象
m = folium.Map(location=[latitude, longitude], zoom_start=zoom_start)

print("Folium地图初始化完成。")

4. 创建并定制化图表

接下来,我们将使用Matplotlib创建一个示例图表。您可以根据实际需求创建任何类型的图表,例如柱状图、折线图、散点图等。这里以一个简单的柱状图为例。

Matlab语言的特点 中文WORD版
Matlab语言的特点 中文WORD版

本文档主要讲述的是Matlab语言的特点;Matlab具有用法简单、灵活、程式结构性强、延展性好等优点,已经逐渐成为科技计算、视图交互系统和程序中的首选语言工具。特别是它在线性代数、数理统计、自动控制、数字信号处理、动态系统仿真等方面表现突出,已经成为科研工作人员和工程技术人员进行科学研究和生产实践的有利武器。希望本文档会给有需要的朋友带来帮助;感兴趣的朋友可以过来看看

下载
import matplotlib.pyplot as plt

# 准备图表数据
data = [10, 20, 30, 40, 50]
labels = ['A', 'B', 'C', 'D', 'E']

# 创建Matplotlib图表
plt.figure(figsize=(6, 4)) # 可以设置图表大小
plt.bar(labels, data, color='skyblue')
plt.xlabel('分类')
plt.ylabel('数值')
plt.title('示例柱状图')
plt.grid(axis='y', linestyle='--') # 添加网格线

print("Matplotlib图表创建完成。")

5. 将图表转换为交互式HTML

这是实现图表在Folium地图中交互显示的关键一步。mpld3库能够将Matplotlib生成的图表转换为基于D3.js的交互式HTML代码。

import mpld3

# 将当前Matplotlib图表转换为HTML
# plt.gcf() 获取当前活动的图表对象
chart_html = mpld3.fig_to_html(plt.gcf())

# 关闭Matplotlib图表,防止在Jupyter环境中显示两次
plt.close()

print("Matplotlib图表已转换为HTML。")

6. 将HTML图表添加到Folium标记的弹出窗口

现在,我们将创建地图上的一个标记,并将之前生成的HTML图表作为该标记的弹出内容。当用户点击地图上的标记时,该图表将以交互式弹窗的形式展现。

# 定义标记的坐标(例如:天安门广场附近)
marker_latitude, marker_longitude = 39.9087, 116.3975

# 创建一个Folium标记
marker = folium.Marker(location=[marker_latitude, marker_longitude])

# 创建一个Folium Popup,并将图表HTML内容作为其内容
# max_width 参数可以控制弹出窗口的最大宽度
popup = folium.Popup(chart_html, max_width=600)

# 将Popup添加到Marker
marker.add_child(popup)

# 将Marker添加到地图
marker.add_to(m)

print("HTML图表已作为弹出窗口添加到Folium标记。")

7. 保存并查看地图

最后一步是将生成的Folium地图保存为HTML文件。您可以在任何现代网络浏览器中打开此文件来查看结果。

# 保存地图为HTML文件
output_file = 'map_with_interactive_chart.html'
m.save(output_file)

print(f"地图已保存到 {output_file}。请在浏览器中打开此文件查看。")

8. 完整示例代码

import folium
import matplotlib.pyplot as plt
import mpld3

# --- 1. 初始化Folium地图 ---
latitude, longitude = 39.9042, 116.4074 # 北京中心坐标
zoom_start = 12
m = folium.Map(location=[latitude, longitude], zoom_start=zoom_start)

# --- 2. 创建并定制化图表 ---
data = [10, 20, 30, 40, 50]
labels = ['A', 'B', 'C', 'D', 'E']

plt.figure(figsize=(7, 4)) # 设置图表大小
plt.bar(labels, data, color=['skyblue', 'lightcoral', 'lightgreen', 'gold', 'lightpink'])
plt.xlabel('分类')
plt.ylabel('数值')
plt.title('地理数据分析示例图表')
plt.grid(axis='y', linestyle='--', alpha=0.7)
plt.tight_layout() # 调整布局,防止标签重叠

# --- 3. 将图表转换为交互式HTML ---
chart_html = mpld3.fig_to_html(plt.gcf())
plt.close() # 关闭Matplotlib图表

# --- 4. 将HTML图表添加到Folium标记的弹出窗口 ---
marker_latitude, marker_longitude = 39.9087, 116.3975 # 标记位置
marker = folium.Marker(location=[marker_latitude, marker_longitude],
                       tooltip="点击查看图表", # 鼠标悬停提示
                       icon=folium.Icon(color='red', icon='info-sign')) # 自定义标记图标

popup = folium.Popup(chart_html, max_width=650) # 设置弹出窗口最大宽度
marker.add_child(popup)
marker.add_to(m)

# --- 5. 保存并查看地图 ---
output_file = 'map_with_interactive_chart_full_example.html'
m.save(output_file)

print(f"教程完成!地图已保存到 {output_file}。请在浏览器中打开此文件查看交互式图表。")

9. 注意事项与总结

  • 交互性: mpld3转换的图表具有基本的交互性,例如鼠标悬停显示数据点信息、缩放等。这比简单的图片嵌入提供了更好的用户体验。
  • 内容限制: 尽管可以将复杂的HTML内容嵌入到Folium的Popup中,但应注意避免过大的HTML内容可能导致地图加载缓慢或弹出窗口显示异常。
  • 直接嵌入: 本教程采用的是将图表嵌入到标记的弹出窗口中。如果需要将图表直接作为地图上的一个控件或层级显示(如原始问题中的GIF所示),可能需要更高级的JavaScript或使用像ipyleaflet这样的库,它提供了更直接的Python-JavaScript桥接能力来控制Leaflet组件。然而,对于大多数用例,通过弹出窗口显示图表是一种简洁而有效的解决方案。
  • 自定义: 您可以根据需要进一步定制Matplotlib图表的外观,以及Folium标记和弹出窗口的样式。

通过本教程,您已经掌握了在Folium地图中集成交互式图表的方法,这为您的地理空间数据分析和可视化提供了强大的工具

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

530

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

554

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

718

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

6024

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

492

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.09.04

Js中concat和push的区别
Js中concat和push的区别

Js中concat和push的区别:1、concat用于将两个或多个数组合并成一个新数组,并返回这个新数组,而push用于向数组的末尾添加一个或多个元素,并返回修改后的数组的新长度;2、concat不会修改原始数组,是创建新的数组,而push会修改原数组,将新元素添加到原数组的末尾等等。本专题为大家提供concat和push相关的文章、下载、课程内容,供大家免费下载体验。

240

2023.09.14

js截取字符串的方法介绍
js截取字符串的方法介绍

JavaScript字符串截取方法,包括substring、slice、substr、charAt和split方法。这些方法可以根据具体需求,灵活地截取字符串的不同部分。在实际开发中,根据具体情况选择合适的方法进行字符串截取,能够提高代码的效率和可读性 。

300

2023.09.21

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

23

2026.03.06

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 5.8万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 3.3万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号