一、folium介紹
1.folium.Map參數(shù)簡要介紹
1、location地圖中心點(diǎn) 經(jīng)緯度,list 或者 tuple 格式,順序?yàn)?latitude(緯度), longitude(經(jīng)度)
2、zoom_start地圖等級 縮放值,默認(rèn)為 10,值越大比例尺越小,地圖放大級別越大
3、tiles 顯示樣式,默認(rèn)*‘OpenStreetMap’*,也就是開啟街道顯示;也有一些其他的內(nèi)建地圖樣式,如’Stamen Terrain’、‘Stamen Toner’、‘Mapbox Bright’、'Mapbox Control Room’等;也可以傳入’None’來繪制一個沒有風(fēng)格的樸素地圖,或傳入一個URL來使用其它的自選osm
4、crs 地理坐標(biāo)參考系統(tǒng),默認(rèn)為"EPSG3857"
5、width:int型或str型,int型時,傳入的是地圖寬度的像素值;str型時,傳入的是地圖寬度的百分比,形式為’xx%‘。默認(rèn)為’100%’
6、height:控制地圖的高度,格式同width
7、max_zoom:int型,控制地圖可以放大程度的上限,默認(rèn)為18
8、attr:str型,當(dāng)在tiles中使用自選URL內(nèi)的osm時使用,用于給自選osm命名
9、control_scale:bool型,控制是否在地圖上添加比例尺,默認(rèn)為False即不添加
10、no_touch:bool型,控制地圖是否禁止接受來自設(shè)備的觸控事件譬如拖拽等,默認(rèn)為False,即不禁止
2.folium.Marker參數(shù)介紹
1、location:同folium.Map()中的同名參數(shù),用于確定標(biāo)記部件的經(jīng)緯位置
2、popup:str型或folium.Popup()對象輸入,用于控制標(biāo)記部件的具體樣式(folium內(nèi)部自建了許多樣式),默認(rèn)為None,即不顯示部件
3、icon:folium.Icon()對象,用于設(shè)置popup定義的部件的具體顏色、圖標(biāo)內(nèi)容等文章來源:http://www.zghlxwxcb.cn/news/detail-622169.html
二、Python根據(jù)經(jīng)緯度在地圖上顯示(示例)
文章來源地址http://www.zghlxwxcb.cn/news/detail-622169.html
1.經(jīng)緯度坐標(biāo)標(biāo)記
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], # 中心點(diǎn)
zoom_start=8, # 初始地圖等級
# 騰訊地圖瓦片
tiles='http://rt1.map.gtimg.com/realtimerender?z={z}&x={x}&y={-y}&type=vector&style=6',
# 默認(rèn)參數(shù)
attr='default')
flag = False # 是否使用聚合
if flag:
# 創(chuàng)建聚合
marker_cluster = MarkerCluster().add_to(m)
# for循環(huán)添加標(biāo)記點(diǎn)
for i in range(len(data_1)):
folium.Marker(location=[data_1.loc[i, '緯度'], data_1.loc[i, '經(jīng)度']], # 坐標(biāo)用[緯度,經(jīng)度]
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, '經(jīng)度']], # 坐標(biāo)用[緯度,經(jīng)度]
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循環(huán)添加標(biāo)記點(diǎn)
for i in range(len(data_1)):
folium.Marker(location=[data_1.loc[i, '緯度'], data_1.loc[i, '經(jīng)度']], # 坐標(biāo)用[緯度,經(jīng)度]
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, '經(jīng)度']], # 坐標(biāo)用[緯度,經(jīng)度]
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)
'''為地圖對象添加點(diǎn)擊顯示經(jīng)緯度的子功能'''
m.add_child(folium.LatLngPopup())
# 點(diǎn)擊新增
# m.add_child(folium.ClickForMarker())
m.save('坐標(biāo)分布圖.html')
2.經(jīng)緯度坐標(biāo)分組標(biāo)記
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], # 地圖中心點(diǎn)
tiles=None,
control_scale=True, # 顯示比例尺
zoom_start=8) # 初始等級
folium.TileLayer(tiles=tile, attr='default', name='省').add_to(m) # 地圖瓦片添加命名
# #創(chuàng)建組
for i in distriction:
exec(str(i) + ' = ' + 'FeatureGroup(name="' + str(i) + '",show=False).add_to(m)')
# 創(chuàng)建聚合
for j in distriction:
# 是否將臨近點(diǎn)聚合
# exec(str(j) + 'mc = ' + 'MarkerCluster().add_to(' + str(j) + ')')
exec(str(j) + 'mc = ' + str(j))
# for循環(huán)添加標(biāo)記點(diǎn)
for k in range(len(df_1)):
exec('''folium.Marker(location=[df_1.loc[k,'緯度'], df_1.loc[k,'經(jīng)度']],
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,'經(jīng)度']],
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)
'''為地圖對象添加點(diǎn)擊顯示經(jīng)緯度的子功能'''
m.add_child(folium.LatLngPopup())
m.save('省市坐標(biāo)分布圖.html') # 保存到當(dāng)前目錄下
到了這里,關(guān)于Python根據(jù)經(jīng)緯度在地圖上顯示(folium)的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!