Python根据经纬度在地图上显示(folium)

news2024/11/22 14:58:37

Python根据经纬度在地图上显示(folium)

  • 一、folium介绍
    • 1.folium.Map参数简要介绍
    • 2.folium.Marker参数介绍
  • 二、Python根据经纬度在地图上显示(示例)
    • 1.经纬度坐标标记
    • 2.经纬度坐标分组标记

一、folium介绍

1.folium.Map参数简要介绍

1、location地图中心点 经纬度,list 或者 tuple 格式,顺序为 latitude(纬度), longitude(经度)

2、zoom_start地图等级 缩放值,默认为 10,值越大比例尺越小,地图放大级别越大

3、tiles 显示样式,默认*‘OpenStreetMap’*,也就是开启街道显示;也有一些其他的内建地图样式,如’Stamen Terrain’、‘Stamen Toner’、‘Mapbox Bright’、'Mapbox Control Room’等;也可以传入’None’来绘制一个没有风格的朴素地图,或传入一个URL来使用其它的自选osm

4、crs 地理坐标参考系统,默认为"EPSG3857"

5、width:int型或str型,int型时,传入的是地图宽度的像素值;str型时,传入的是地图宽度的百分比,形式为’xx%‘。默认为’100%’

6、height:控制地图的高度,格式同width

7、max_zoom:int型,控制地图可以放大程度的上限,默认为18

8、attr:str型,当在tiles中使用自选URL内的osm时使用,用于给自选osm命名

9、control_scale:bool型,控制是否在地图上添加比例尺,默认为False即不添加

10、no_touch:bool型,控制地图是否禁止接受来自设备的触控事件譬如拖拽等,默认为False,即不禁止

2.folium.Marker参数介绍

1、location:同folium.Map()中的同名参数,用于确定标记部件的经纬位置

2、popup:str型或folium.Popup()对象输入,用于控制标记部件的具体样式(folium内部自建了许多样式),默认为None,即不显示部件

3、icon:folium.Icon()对象,用于设置popup定义的部件的具体颜色、图标内容等

二、Python根据经纬度在地图上显示(示例)

在这里插入图片描述

1.经纬度坐标标记

import pandas as pd
import folium
from folium.plugins import MarkerCluster

data = pd.read_excel('******.xlsx')  # 读取文件
data_1 = data[data['类型'] == '***1']
data_2 = data[data['类型'] == '***2']
data_1.reset_index(inplace=True, drop=True)
data_2.reset_index(inplace=True, drop=True)
# print(data_1.head())
# print(data_2.head())
# exit()
m = folium.Map(location=[31.97117, 116.49872],  # 中心点
               zoom_start=8,  # 初始地图等级
               # 腾讯地图瓦片
               tiles='http://rt1.map.gtimg.com/realtimerender?z={z}&x={x}&y={-y}&type=vector&style=6',
               # 默认参数
               attr='default')
flag = False  # 是否使用聚合
if flag:
    # 创建聚合
    marker_cluster = MarkerCluster().add_to(m)
    # for循环添加标记点
    for i in range(len(data_1)):
        folium.Marker(location=[data_1.loc[i, '纬度'], data_1.loc[i, '经度']],  # 坐标用[纬度,经度]
                      popup=folium.Popup(str(data_1.loc[i, 'NAME']),
                                         parse_html=True,
                                         tooltip=str(data_1.loc[i, 'NAME']),
                                         max_width=100),  # 提示语横向完全显示
                      icon=folium.Icon(color='red')
                      ).add_to(marker_cluster)
    for j in range(len(data_2)):
        folium.Marker(location=[data_2.loc[j, '纬度'], data_2.loc[j, '经度']],  # 坐标用[纬度,经度]
                      popup=folium.Popup(str(data_2.loc[j, 'NAME']),
                                         parse_html=True,
                                         tooltip=str(data_2.loc[j, 'NAME']),
                                         max_width=100),  # 提示语横向完全显示
                      icon=folium.Icon(color='blue')
                      ).add_to(marker_cluster)
else:
    # for循环添加标记点
    for i in range(len(data_1)):
        folium.Marker(location=[data_1.loc[i, '纬度'], data_1.loc[i, '经度']],  # 坐标用[纬度,经度]
                      popup=folium.Popup(str(data_1.loc[i, 'NAME']),
                                         parse_html=True,
                                         tooltip=str(data_1.loc[i, 'NAME']),
                                         max_width=100),  # 提示语横向完全显示
                      icon=folium.Icon(color='red'),
                      ).add_to(m)
    for j in range(len(data_2)):
        folium.Marker(location=[data_2.loc[j, '纬度'], data_2.loc[j, '经度']],  # 坐标用[纬度,经度]
                      popup=folium.Popup(str(data_2.loc[j, 'NAME']),
                                         parse_html=True,
                                         tooltip=str(data_2.loc[j, 'NAME']),
                                         max_width=100),  # 提示语横向完全显示
                      icon=folium.Icon(color='blue'),
                      ).add_to(m)
'''为地图对象添加点击显示经纬度的子功能'''
m.add_child(folium.LatLngPopup())
# 点击新增
# m.add_child(folium.ClickForMarker())
m.save('坐标分布图.html')

2.经纬度坐标分组标记

import pandas as pd
import folium
from folium.plugins import MarkerCluster
from folium import FeatureGroup, LayerControl

tile = 'http://rt1.map.gtimg.com/realtimerender?z={z}&x={x}&y={-y}&type=vector&style=0'

df = pd.read_excel('******.xlsx')  # 读取文件
df_1 = df[df['类型'] == '***1']
df_2 = df[df['类型'] == '***2']
df_1.reset_index(inplace=True, drop=True)
df_2.reset_index(inplace=True, drop=True)
distriction = df['所属市'].drop_duplicates()

m = folium.Map(location=[30.97117, 132.49872],  # 地图中心点
               tiles=None,
               control_scale=True,  # 显示比例尺
               zoom_start=8)  # 初始等级
folium.TileLayer(tiles=tile, attr='default', name='省').add_to(m)  # 地图瓦片添加命名

# #创建组
for i in distriction:
    exec(str(i) + ' = ' + 'FeatureGroup(name="' + str(i) + '",show=False).add_to(m)')

# 创建聚合
for j in distriction:
    # 是否将临近点聚合
    # exec(str(j) + 'mc = ' + 'MarkerCluster().add_to(' + str(j) + ')')
    exec(str(j) + 'mc = ' + str(j))

# for循环添加标记点
for k in range(len(df_1)):
    exec('''folium.Marker(location=[df_1.loc[k,'纬度'], df_1.loc[k,'经度']],  
                  popup=folium.Popup(str(df_1.loc[k,'NAME']), 
                                     parse_html=True, 
                                     max_width=150),                #提示语横向完全显示
                  icon=folium.Icon(color='red')      
                 ).add_to(''' + str(df_1.loc[k, '所属市']) + 'mc)')
for k in range(len(df_2)):
    exec('''folium.Marker(location=[df_2.loc[k,'纬度'], df_2.loc[k,'经度']],  
                  popup=folium.Popup(str(df_2.loc[k,'NAME']), 
                                     parse_html=True, 
                                     max_width=150),                #提示语横向完全显示 
                  icon=folium.Icon(color='blue')      
                 ).add_to(''' + str(df_2.loc[k, '所属市']) + 'mc)')

LayerControl(collapsed=False).add_to(m)
'''为地图对象添加点击显示经纬度的子功能'''
m.add_child(folium.LatLngPopup())
m.save('省市坐标分布图.html')  # 保存到当前目录下

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/575616.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

URLConnection(五)

文章目录 1. 断开与服务器的连接2. 处理服务器响应3. 错误条件4. 重定向5. 代理6. 流模式 1. 断开与服务器的连接 HTTP1.1 支持持久连接,允许通过一个TCP socket发送多个请求和响应。不过使用Keep-Alive时,服务器不会因为已经向客户端发送了最后一个字节…

chatgpt赋能python:使用Python操作股票软件:探索股票市场的新方式

使用Python操作股票软件:探索股票市场的新方式 在当今股票市场中,许多投资者正在寻找新的方式来更好地管理其投资组合。一种新的方式是使用Python编程语言操作股票软件。Python拥有简洁的语法和丰富的库来帮助投资者更好地理解和管理股票。在本文中&…

挂耳式耳机哪个牌子好?这次推荐准没错!

在校园里,上网课、复习考证、刷视频……耳机总是我的第一选择,既不会打扰别人又能有效学习,普通的入耳式耳机戴久了总是会耳道痛,甚至出现耳道发炎问题,耳机也总是很难清洁。但是生活中我又离不开耳机,所以…

【源码解析】分库分表框架 Shardingsphere 源码解析

前言 以前研究过如何使用ShardingJdbc,使用ShardingJdbc进行分库分表,但是原理方面没有细致的深入了解。如果仅仅了解如何使用的话,对于改造和排查问题,其实都是不够的,所以跟踪源码了解其运行原理是很重要的。 Demo…

GPT学习笔记-Embedding的降维与2D,3D可视化

嵌入(Embedding)在机器学习和自然语言处理中是一种表示离散变量(如单词、句子或整个文档)的方式,通常是作为高维向量或者矩阵。嵌入的目标是捕捉到输入数据中的语义信息,使得语义相近的元素在嵌入空间中的距…

STM32+UART串口+DMA收发

目录 1、cubemax端配置 1.1 初始化配置 1.2 GPIO配置 1.3 UART配置 1.3.1 串口基础配置 1.3.2 DMA配置 2、keil端代码设计 2.1 初始化配置 2.2 DMA接收初始化配置 2.3 DMA发送配置 2.4 接收回调函数设置 2.5 回调函数内容代码编写 2.5.1 接收回调函数 2.5.2 发送回调…

最优化理论-最速下降法的推导与应用

目录 1. 引言 2. 最速下降法的基本原理 3. 最速下降法的推导过程 3.1 梯度和梯度下降 3.2 最速下降法的数学表述 4. 最速下降法的应用 4.1 无约束优化问题 4.2 约束优化问题 5. 最速下降法的优缺点 6. 结论 7.代码实现 1. 引言 在最优化理论中,最速下降法…

3W字吃透:微服务网关SpringCloud gateway底层原理和实操

40岁老架构师尼恩的掏心窝: 现在拿到offer超级难,甚至连面试电话,一个都搞不到。 尼恩的技术社群中(50),很多小伙伴凭借 “左手云原生 右手大数据 SpringCloud Alibaba 微服务“三大绝活,拿…

Dock的安装和使用

1、docker基础 三大组件: 仓库、镜像、容器什么是docker: 通俗来讲就是提供服务的容器Docker 两个概念:容器:可以看做空间 例如:磁盘、文件夹 镜像:灵魂 例如:系统、应用 一个镜像可以放在多个容器中(就如同把同一个文件复制到多个磁盘或文件夹一样) 一个容器可以放多个镜…

【Nginx】实战应用(服务器端集群搭建、下载站点、用户认证模块)

文章目录 Nginx实现服务器端集群搭建Nginx与Tomcat部署环境准备(Tomcat)环境准备(Nginx) Nginx实现动静分离需求分析动静分离实现步骤 Nginx实现Tomcat集群搭建 Nginx高可用解决方案KeepalivedVRRP环境搭建Keepalived配置文件介绍访问测试keepalived之vrrp_script Nginx制作下载…

python中的常见运算符

文章目录 算数运算符赋值运算关系运算符逻辑运算符非布尔值的与或非运算条件运算符(也叫三元运算符)运算符的优先级 算数运算符 加法运算符(如果两个字符串之间进行加法运算,则会进行拼串操作) - 减法运算符 * 乘法运算符(如果将字…

小鹏汽车Q1财报:押注G6、大力降本,明年智驾BOM降半

‍作者 | 德新编辑 | 王博 小鹏汽车本周发了Q1财报,数据不好看,以致于在微博端也发了公开信。 那后续呢? 小鹏第二季度指引是,总交付数量约为2.1 - 2.2万辆,收入预计约为45 - 47亿元;四季度&#xff0c…

Selective Kernel Networks论文总结和代码实现

论文:https://arxiv.org/abs/1903.06586?contextcs 中文版:(CVPR-2019)选择性的内核网络_sk卷积 源码:GitHub - implus/SKNet: Code for our CVPR 2019 paper: Selective Kernel Networks 目录 一、论文出发点 二、论文主要工作 三、SK模…

洛谷——树

洛谷——树 文章目录 洛谷——树树的重心会议题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示数据范围 思路 树的直径【XR-3】核心城市题目描述输入格式输出格式样例 #1样例输入 #1样例输出 #1 提示思路 [NOI2003] 逃学的小孩题目描述输入格式输出格式样例 #1样例…

Cocos creator实现《滑雪趣挑战》滑雪小游戏资源及代码

Cocos creator实现《滑雪趣挑战》滑雪小游戏资源及代码 最近在学习Cocos Creator,作为新手,刚刚开始学习Cocos Creator,上线了两个微信小游戏,刚刚入门,这里记录一下《滑雪趣挑战》实现及上线过程的过程。 ](https://…

vue实现深拷贝的方法

在 vue中,深拷贝是一个很有用的功能,在不改变原来对象状态的情况下,进行对象的复制。 但要实现深拷贝,需要两个对象具有相同的属性。如果两个对象不同,深拷贝也不能实现。 1.我们将变量A的属性赋给变量B,但…

springboot+java医院门诊挂号系统设计与实现ssm008

本课题的目标是使医院门诊信息管理清晰化,透明化,便于操作,易于管理。通过功能模块的优化组合实现不同的管理细节,使管理过程实现最大程度的自动化与信息化,并能自动对人工操作环节进行复查,使医院门诊挂号系统出错率降至最低。 主…

3、mqtt客户端演示(MQTT通信协议(mosquitto)发布订阅 C语言实现)

可订阅可发布模式 具体代码 客户端1代码&#xff1a;pub.c #include <stdio.h> #include <stdlib.h> #include <mosquitto.h> #include <string.h>#define HOST "localhost" #define PORT 1883 #define KEEP_ALIVE 60 #define MSG_MAX_S…

ChatGPT提示词工程进阶教学

ChatGPT提示词工程 1 两种大型语言模型LLM1.1 基础大模型&#xff08;base LLM&#xff09;1.2 指令调优大模型(Instruction Tuned LLM) 2 如何更清晰、具体地书写提示词2.1 在提示词中使用“定界符”2.2 向模型请求结构化的输出2.3 要求模型检查任务条件是否满足2.4 输入多范例…

uCOSii中的互斥信号量

uCOSii中的互斥信号量 一、互斥型信号量项管理 (MUTUAL EXCLUSION SEMAPHORE MANAGEMENT) OSMutexAccept() 无条件等待地获取互斥型信号量 OSMutexCreate() 建立并初始化一个互斥型信号量 OSMutexDel() 删除互斥型信号量 OSMutexPend() 等待一个互斥型信号量 OSMutexPost…