当前位置: 首页 > news >正文

python地图库(一)—folium

目录

区域地图绘制 

世界地图

国家地图

市级地图

地图样式

地图标记

普通标记(图标标记)

圆圈标记

点击鼠标获取经纬度

动态标记

热力图绘制

密度地图绘制

保存地图


为了方便展示地图,通过安装jupyter,在网页端直接显示

安装Jupyter:pip install   jupyter

运行Jupyter,在命令行执行jupyter-notebook后会直接打开网页(http://localhost:8888/tree),显示对应的路径下的文件目录

重点参数:
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 folium

world_map = folium.Map()
world_map

国家地图

national_map = folium.Map(location=[30.3, 100.6], zoom_start=4)
national_map

市级地图

改变地图显示就是改变显示的经纬度和缩放比例,省级、市级、县级用法雷同

city_map = folium.Map(location=[39.93, 116.40], zoom_start=10)
city_map

地图样式

除了上述正常的地图显示外,folium 还提供了非常丰富的多样化显示,控制显示效果的变量是tiles,样式有OpenStreetMap, Stamen Terrain,Stamen Toner等

# city_map = folium.Map(location=[34.36,108.93], zoom_start=10, tiles='OpenStreetMap')  # 默认样式OpenStreetMap
city_map = folium.Map(location=[34.36,108.93], zoom_start=10, tiles='Stamen Terrain')
city_map

city_map = folium.Map(location=[34.36,108.93], zoom_start=10, tiles='Stamen Toner')
city_map

 

地图标记

普通标记(图标标记)

添加普通标记用 Marker,可以选择标记的图案 

m = folium.Map(location=[34.36,108.93], zoom_start=10)
folium.Marker(
    location=[35.36,107.93],
    popup='Mt. Hood Meadows',  # # 图标说明,点击图标显示
    icon=folium.Icon(icon='cloud')
).add_to(m)

folium.Marker(
    location=[35.06, 107.32],
    popup='Timberline Lodge',
    icon=folium.Icon(color='green')
).add_to(m)

folium.Marker(
    location=[35.00, 107.01],
    popup='Some Other Location',
    icon=folium.Icon(color='red', icon='info-sign')
).add_to(m)
m

圆圈标记

添加圆形标记用 Circle 以及 CircleMarker

Circle标记,这种标记通过地图缩放圈的大小随之改变,圈选区域不变

map = folium.Map(location=[34.36,108.93], zoom_start=10)
folium.Circle(
    radius=10000,
    location=[34.37, 108.83],
    popup='Circle标记,这种标记通过地图缩放圈的大小随之改变,圈选区域不变',
    color='crimson',
    fill=True,   # 填充
).add_to(map)
map

CircleMarker标记方式,这种标记缩放地图圈的大小不变,圈选区域会改变

map = folium.Map(location=[34.36,108.93], zoom_start=10)
folium.CircleMarker(
    location=[34.92, 108.90],  # 标记位置坐标
    radius=50,  # 圆的半径
    popup='CircleMarker标记方式,这种标记缩放地图圈的大小不变,圈选区域会改变',
    color='#3186cc',  # 标记外圈颜色
    fill=True,  # 是否填充
    fill_color='#3186cc',  # 填充色
    fill_opacity=0.4  # 填充透明度
).add_to(map)
map

点击鼠标获取经纬度

m = folium.Map(location=[34.36,108.93],zoom_start=13)
m.add_child(folium.LatLngPopup())
m

动态标记

m = folium.Map(location=[34.36,108.93],tiles='Stamen Terrain',zoom_start=13)
m.add_child(folium.ClickForMarker(popup='新增标记'))
m

热力图绘制

import numpy as np
import folium
from folium.plugins import HeatMap
data = (
    np.random.normal(size=(100, 3)) *
    np.array([[0.1, 0.1, 0.1]]) +
    np.array([[34.36,108.93, 1]])
).tolist()

m = folium.Map([34.93, 108.38],zoom_start=8)
HeatMap(data).add_to(m)
m

密度地图绘制

import folium
from folium.plugins import MarkerCluster

m = folium.Map([34.36,108.93], tiles='stamentoner', zoom_start=10)

# create a mark cluster object
marker_cluster = MarkerCluster().add_to(m)

# add data point to the mark cluster
for lat, lng, label in data:
    folium.Marker(
        location=[lat, lng],
        icon=None,
        popup=label,
    ).add_to(marker_cluster)

# add marker_cluster to map
m.add_child(marker_cluster)

保存地图

将地图保存为网页形式,可以直接在浏览器打开查看

import folium

city_map = folium.Map(location=[34.36,108.93], zoom_start=10, tiles='Stamen Terrain')
city_map.save('地图.html')

相关文章:

  • cesium拾取pick系列(拾取坐标和对象)
  • 说一说js继承的方法和优缺点?
  • ARMv8/ARMv9的Exclusive机制深度解读
  • 机器学习——梯度下降算法
  • 64.【网络编程】
  • Python爬虫-网页认识
  • 面试官:深度不够,建议回去深挖
  • [ vulhub漏洞复现篇 ] Apache APISIX 默认密钥漏洞 CVE-2020-13945
  • 接口测试用例生成工具介绍及应用
  • C#接入 NPOI
  • 面试百问:项目上线后才发现bug怎么办?
  • SpringBoot+Vue实现前后端分离网上药店平台
  • Simulink 自动代码生成电机控制:基于Keil软件集成
  • LQ0103 子串分值【字符串】
  • 数据库实战经验分享(全量表,增量表,拉链表,流水表,快照表)
  • E-HPC支持多队列管理和自动伸缩
  • JAVA SE 6 GC调优笔记
  • Java面向对象及其三大特征
  • PHP 小技巧
  • scrapy学习之路4(itemloder的使用)
  • SpriteKit 技巧之添加背景图片
  • VirtualBox 安装过程中出现 Running VMs found 错误的解决过程
  • vue2.0一起在懵逼的海洋里越陷越深(四)
  • web标准化(下)
  • 表单中readonly的input等标签,禁止光标进入(focus)的几种方式
  • 在 Chrome DevTools 中调试 JavaScript 入门
  • 怎样选择前端框架
  • Hibernate主键生成策略及选择
  • 阿里云服务器购买完整流程
  • ​​​​​​​GitLab 之 GitLab-Runner 安装,配置与问题汇总
  • ​linux启动进程的方式
  • ​MPV,汽车产品里一个特殊品类的进化过程
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • (1/2) 为了理解 UWP 的启动流程,我从零开始创建了一个 UWP 程序
  • (二)springcloud实战之config配置中心
  • (附源码)springboot工单管理系统 毕业设计 964158
  • (免费分享)基于springboot,vue疗养中心管理系统
  • (免费领源码)Java#ssm#MySQL 创意商城03663-计算机毕业设计项目选题推荐
  • (十五)Flask覆写wsgi_app函数实现自定义中间件
  • (原創) 博客園正式支援VHDL語法著色功能 (SOC) (VHDL)
  • (转)关于如何学好游戏3D引擎编程的一些经验
  • .bat批处理(一):@echo off
  • .NET DataGridView数据绑定说明
  • .Net MVC4 上传大文件,并保存表单
  • .net 程序发生了一个不可捕获的异常
  • .NET 服务 ServiceController
  • .net 桌面开发 运行一阵子就自动关闭_聊城旋转门家用价格大约是多少,全自动旋转门,期待合作...
  • .NET/C# 解压 Zip 文件时出现异常:System.IO.InvalidDataException: 找不到中央目录结尾记录。
  • .NET成年了,然后呢?
  • .NET的数据绑定
  • //解决validator验证插件多个name相同只验证第一的问题
  • /var/log/cvslog 太大
  • [2024最新教程]地表最强AGI:Claude 3注册账号/登录账号/访问方法,小白教程包教包会
  • [④ADRV902x]: Digital Filter Configuration(发射端)
  • [Android 13]Input系列--获取触摸窗口