日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術(shù)文章
文章詳情頁

Python繪制地圖神器folium的新人入門指南

瀏覽:48日期:2022-06-18 16:10:07
目錄一、簡介二、安裝方法三、主要功能3.1 各級別地圖 3.1.1 世界地圖3.1.2 國家地圖3.1.3 市級地圖3.2 地圖形式3.3 在地圖上標記3.3.1 普通標記3.3.2 點擊獲取經(jīng)緯度3.3.3 動態(tài)放置標記3.4 熱力圖繪制3.5 密度地圖繪制3.6 自定義地圖區(qū)域3.6.1 只繪制邊界,不添加數(shù)據(jù)3.6.2 繪制邊界,添加數(shù)據(jù)四、競品對比與優(yōu)劣勢五、參考資料一、簡介

想通過 Python 繪制精美的地圖?想在地圖上自由的設(shè)置各種參數(shù)?想獲得靈活的交互體驗?這里就有一款Python 神包滿足你:folium

folium 建立在 Python 生態(tài)系統(tǒng)的數(shù)據(jù)應(yīng)用能力和 Leaflet.js 庫的映射能力之上,在Python中操作數(shù)據(jù),然后通過 folium 在 Leaflet 地圖中可視化。

folium 相比較于國內(nèi)百度的 pyecharts 靈活性更強,能夠自定義繪制區(qū)域,并且展現(xiàn)形式更加多樣化。

附:官方文檔,官方示例,本文 notebook ,完整代碼及數(shù)據(jù)。

二、安裝方法

按照官方的教程即可,如果安裝了 conda ,可以直接

conda install -c conda-forge folium

沒有安裝的話就使用

python3 -m pip install folium三、主要功能3.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)

講幾個重要的參數(shù)

location 經(jīng)緯度,list 或者 tuple 格式,順序為 latitude, longitude zoom_start 縮放值,默認為 10,值越大比例尺越小,地圖放大級別越大 tiles 顯示樣式,默認*‘OpenStreetMap’*,也就是開啟街道顯示 crs 地理坐標參考系統(tǒng),默認為'EPSG3857' 3.1.1 世界地圖

import foliumprint(folium.__version__)# define the world mapworld_map = folium.Map()# display world mapworld_map

Python繪制地圖神器folium的新人入門指南

3.1.2 國家地圖

# define the national mapnational_map = folium.Map(location=[35.3, 100.6], zoom_start=4)# display national mapnational_map

Python繪制地圖神器folium的新人入門指南

3.1.3 市級地圖

其實改變地圖顯示就是改變顯示的經(jīng)緯度和縮放比例,省級、市級、縣級用法雷同,這里舉一個市級的例子為例,如北京市:

# define the city mapcity_map = folium.Map(location=[39.93, 116.40], zoom_start=10)# display city mapcity_map

Python繪制地圖神器folium的新人入門指南

顯示效果確實是不如百度的😓。

3.2 地圖形式

除了上述正常的地圖顯示外,folium 還提供了非常豐富的多樣化顯示,控制顯示效果的變量是tiles,樣式有OpenStreetMap, Stamen Terrain, Stamen Toner, Mapbox Bright, Mapbox Control Room等等,這里挑選幾個比較常見的

# define the city map,tiles=’Stamen Toner’city_map = folium.Map(location=[39.93, 116.40], zoom_start=10, tiles=’Stamen Toner’)# display city mapcity_map

# define the city map, tiles=’Stamen Terrain’city_map = folium.Map(location=[39.93, 116.40], zoom_start=10, tiles=’Stamen Terrain’)# display city mapcity_map

Python繪制地圖神器folium的新人入門指南

3.3 在地圖上標記3.3.1 普通標記

添加普通標記用 Marker

這里可以選擇標記的圖案。

bj_map = folium.Map(location=[39.93, 115.40], zoom_start=12, tiles=’Stamen Terrain’)folium.Marker( location=[39.95, 115.33], popup=’Mt. Hood Meadows’, icon=folium.Icon(icon=’cloud’)).add_to(bj_map)folium.Marker( location=[39.96, 115.32], popup=’Timberline Lodge’, icon=folium.Icon(color=’green’)).add_to(bj_map)folium.Marker( location=[39.93, 115.34], popup=’Some Other Location’, icon=folium.Icon(color=’red’, icon=’info-sign’)).add_to(bj_map)bj_map

Python繪制地圖神器folium的新人入門指南

添加圓形標記用 Circle 以及 CircleMarker

bj_map = folium.Map(location=[39.93, 116.40], zoom_start=12, tiles=’Stamen Toner’)folium.Circle( radius=200, location=[39.92, 116.43], popup=’The Waterfront’, color=’crimson’, fill=False,).add_to(bj_map)folium.CircleMarker( location=[39.93, 116.38], radius=50, popup=’Laurelhurst Park’, color=’#3186cc’, fill=True, fill_color=’#3186cc’).add_to(bj_map)bj_map

Python繪制地圖神器folium的新人入門指南

3.3.2 點擊獲取經(jīng)緯度

m = folium.Map(location=[46.1991, -122.1889],tiles=’Stamen Terrain’,zoom_start=13)m.add_child(folium.LatLngPopup())m

通過點擊鼠標便可以獲取點擊出的經(jīng)緯度。

Python繪制地圖神器folium的新人入門指南

3.3.3 動態(tài)放置標記

m = folium.Map( location=[46.8527, -121.7649], tiles=’Stamen Terrain’, zoom_start=13)folium.Marker( [46.8354, -121.7325], popup=’Camp Muir’).add_to(m)m.add_child(folium.ClickForMarker(popup=’Waypoint’))m

Python繪制地圖神器folium的新人入門指南

3.4 熱力圖繪制

因為沒有實際的經(jīng)緯度坐標數(shù)據(jù),所以這里只能模擬一些位置出來,另外每個位置還需要一個數(shù)值作為熱力值。

# generated dataimport numpy as npdata = ( np.random.normal(size=(100, 3)) * np.array([[0.1, 0.1, 0.1]]) + np.array([[40, 116.5, 1]])).tolist()data[:3]

數(shù)據(jù)分布

[[40.04666663299843, 116.59569796477264, 0.9667425547098781], [39.86836537517533, 116.28201445195315, 0.8708549157348728], [40.08123232852134, 116.56884585184197, 0.9104952244371285]]

繪制熱力圖

# HeatMapfrom folium.plugins import HeatMapm = folium.Map([39.93, 116.38], tiles=’stamentoner’, zoom_start=6)HeatMap(data).add_to(m)# m.save(os.path.join(’results’, ’Heatmap.html’))m

Python繪制地圖神器folium的新人入門指南

3.5 密度地圖繪制

folium 不僅可以繪制熱力圖,還可以繪制密度地圖,按照經(jīng)緯度進行舉例聚類,然后在地圖中顯示。

from folium.plugins import MarkerClusterm = folium.Map([39.93, 116.38], tiles=’stamentoner’, zoom_start=10)# create a mark cluster objectmarker_cluster = MarkerCluster().add_to(m)# add data point to the mark clusterfor lat, lng, label in data: folium.Marker(location=[lat, lng],icon=None,popup=label, ).add_to(marker_cluster)# add marker_cluster to mapm.add_child(marker_cluster)

Python繪制地圖神器folium的新人入門指南

3.6 自定義地圖區(qū)域

folium 一個非常有優(yōu)勢的功能就是自定義區(qū)域的繪制了,只要有區(qū)域的邊界數(shù)據(jù),就可以在地圖中以多種多樣的形式展現(xiàn)出來,這里以 folium 官方的美國地圖為例,源數(shù)據(jù)是一個 .json 文件,里面包含了各個地區(qū)(美國各州)的特征(包括邊界經(jīng)緯度列表、簡稱等),源數(shù)據(jù)傳送門,其數(shù)據(jù)格式如下:

Python繪制地圖神器folium的新人入門指南

3.6.1 只繪制邊界,不添加數(shù)據(jù)

如果只要求繪制邊界,而不顯示邊界區(qū)域的相關(guān)信息,那么這個是比較容易的,代碼如下

import jsonimport requests# read us-states border with open('us-states.json') as f: us_states = json.load(f)us_map = folium.Map(location=[35.3, -97.6], zoom_start=4)folium.GeoJson( us_states, style_function=lambda feature: {’fillColor’: ’#ffff00’,’color’: ’black’,’weight’: 2,’dashArray’: ’5, 5’ }).add_to(us_map)#display mapus_map

Python繪制地圖神器folium的新人入門指南

3.6.2 繪制邊界,添加數(shù)據(jù)

當需要在各個區(qū)域填充數(shù)據(jù)的時候,這個稍微麻煩點,不僅需要各個區(qū)域的邊界數(shù)據(jù),還需要各個區(qū)域的顯示信息,這里同樣也使用官方的美國各州的邊界數(shù)據(jù)為例:

import geopandas as gpdimport pandas as pdimport folium, brancastates = gpd.GeoDataFrame.from_features(us_states, crs=fiona.crs.from_epsg(4326))states.head()

Python繪制地圖神器folium的新人入門指南

我們再把收入等數(shù)據(jù)連接到上表中

abbrs = pd.read_json(open('abbrs.json'))statesmerge = states.merge(abbrs,how=’left’, left_on=’name’, right_on=’name’)statesmerge[’geometry’]=statesmerge.geometry.simplify(.05)income = pd.read_csv('income.csv', dtype={'fips':str})income[’income-2015’]=pd.to_numeric(income[’income-2015’], errors=’coerce’)income.groupby(by='state')[[’state’,’income-2015’]].median().head()statesmerge[’medianincome’]=statesmerge.merge(income.groupby(by='state')[[’state’,’income-2015’]].median(), how=’left’, left_on=’alpha-2’, right_on=’state’)[’income-2015’]statesmerge[’change’]=statesmerge.merge(income.groupby(by='state')[[’state’,’change’]].median(), how=’left’, left_on=’alpha-2’, right_on=’state’)[’change’]statesmerge.head()

Python繪制地圖神器folium的新人入門指南

最終繪制出的來的地圖如下:

Python繪制地圖神器folium的新人入門指南

除此之外,還有很多非常有趣的功能,這里就不一一列舉了,感興趣的可以參考官方的文檔。

四、競品對比與優(yōu)劣勢

國內(nèi)的競品為百度的 pyecharts,和 folium 一樣都可以實現(xiàn)普通的地圖繪制功能,但是具體使用還有較大的區(qū)別,具體如下表

功能 pyecharts folium 備注 世界地圖 可以 可以中文顯示 可以 部分可以 folium地圖中標尺、文字不能正常顯示,但是嵌入地圖中的中文可以正常顯示 交互性 好 好區(qū)(縣)級地圖 可以 可以 folium需要區(qū)(縣)邊界數(shù)據(jù) 市級地圖 可以 可以 folium需要市邊界數(shù)據(jù) 收費 自定義區(qū)域需要購買百度ak 自定義區(qū)域功能免費靈活性 好 好省級地圖 可以 可以 folium需要省邊界數(shù)據(jù) 美觀度 好 較好自定義區(qū)域 部分可以 可以 pyecharts需要百度 ak,folium免費 五、參考資料

[1] https://www.zhihu.com/question/33783546

[2] https://pypi.org/project/folium/

[3] https://nbviewer.jupyter.org/github/python-visualization/folium/tree/master/examples/

到此這篇關(guān)于Python繪制地圖神器folium的文章就介紹到這了,更多相關(guān)Python繪制地圖folium內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標簽: Python 編程
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
国产一区二区久久久久| 精品视频国内| 欧美精品97| 久久国产三级| 国产精品中文| 国产精品久久久一区二区| 日本精品一区二区三区在线观看视频 | 日韩精品亚洲一区二区三区免费| 亚洲一区亚洲| 91久久精品无嫩草影院| 亚洲成人精选| 麻豆高清免费国产一区| 狠狠爱www人成狠狠爱综合网| 久久精品欧美一区| 国产一区久久| 亚洲一区区二区| 亚洲尤物av| 97se亚洲| 国产一区丝袜| 欧美成人精品| 亚洲欧美日韩精品一区二区| 亚洲影视一区二区三区| 国产黄色一区| 国产免费av一区二区三区| 欧美一级专区| 亚洲精品少妇| 国产欧美日韩| 国产成人精品亚洲线观看| 日本欧美不卡| 先锋亚洲精品| 国产日韩在线观看视频| 国内自拍视频一区二区三区| 日韩不卡在线| 三级在线观看一区二区 | 日本精品不卡| 日韩在线卡一卡二| 国产亚洲一区二区三区不卡| 国产精品久久观看| 91tv亚洲精品香蕉国产一区| 国产精品美女| 国产精区一区二区| 日本久久精品| 99国产精品私拍| 欧美精品中文| 亚洲成人一区在线观看| 亚洲精选成人| 精品日产乱码久久久久久仙踪林| 99精品电影| 日韩在线观看中文字幕| 首页国产精品| 亚洲午夜免费| 精品色999| 香蕉精品999视频一区二区| 日韩中文字幕| 国产精品xxx| av在线资源| 国产精品日本| 久久中文字幕一区二区| 精品在线91| 国产亚洲欧美日韩在线观看一区二区| 国产一区二区三区日韩精品| 亚洲国产专区| 国产欧美一区二区三区国产幕精品| 日本免费久久| 日本在线不卡视频| 色老板在线视频一区二区| 日韩一二三区在线观看| 久久久久国产精品一区二区| 一区二区精彩视频| 久久免费高清| 国产精品久一| 天使萌一区二区三区免费观看| 精品香蕉视频| 亚洲午夜国产成人| av一区在线| 国产欧美一区二区精品久久久| 99精品在线免费在线观看| 日韩欧美精品一区二区综合视频| 成人精品亚洲| 免费观看亚洲天堂| 中文不卡在线| 成人羞羞视频在线看网址| 国产免费av国片精品草莓男男 | 欧美片第1页综合| 欧美理论视频| 国产成人免费| 日韩美女国产精品| 一本色道久久精品| 伊人久久av| 久久av超碰| 亚洲影院天堂中文av色| 91精品一区二区三区综合| 麻豆91在线播放| 天堂va欧美ⅴa亚洲va一国产| 激情欧美一区二区三区| 福利片在线一区二区| 欧美日韩精品一区二区三区视频| 久久蜜桃精品| 福利欧美精品在线| 国产极品模特精品一二| 91嫩草精品| 亚洲精品伊人| 中文一区一区三区免费在线观| 国产中文一区| 国产美女高潮在线观看| 久久亚洲道色| 欧美色综合网| 日本一不卡视频| 一区二区国产在线| 午夜一级久久| 影音国产精品| 欧美一区二区三区激情视频 | 国产亚洲一区| 日韩av电影一区| 中文字幕一区日韩精品| 国产手机视频一区二区| 亚洲先锋成人| 欧美日韩水蜜桃| 香蕉精品久久| 999久久久精品国产| 日韩电影免费在线观看| 91日韩欧美| 日韩啪啪电影网| 日本久久黄色| 激情黄产视频在线免费观看| 欧美91在线| 麻豆精品在线播放| 麻豆精品在线观看| 国产成人1区| 成人影视亚洲图片在线| 91青青国产在线观看精品| 福利在线免费视频| www.com.cn成人| 一本大道色婷婷在线| 久久久久久久久久久妇女| 久久中文字幕av一区二区不卡| av一区二区高清| 国产一在线精品一区在线观看| 欧美日韩精品一本二本三本 | 精品视频久久| 福利一区二区免费视频| 日韩欧美自拍| 2023国产精品久久久精品双| 亚洲深夜福利| 中文字幕一区二区三区在线视频| 日韩精品中文字幕吗一区二区| 7m精品国产导航在线| 欧美1区2区3| 在线看片福利| 精品一区欧美| 无码日韩精品一区二区免费| 日韩高清在线不卡| 97se亚洲| а√天堂8资源在线| 亚洲天堂黄色| 亚洲精品黄色| 国产极品嫩模在线观看91精品| 青青青免费在线视频| 亚洲高清久久| 三级欧美韩日大片在线看| 亚洲+小说+欧美+激情+另类| 国产精品久久久久久妇女| 日产午夜精品一线二线三线| 三级精品视频| 亚洲三级网址| 精品久久亚洲| 一区免费在线| 日韩大片免费观看| 亚洲日产国产精品| 精品资源在线| 奇米亚洲欧美| 日本不卡一二三区黄网| 中文字幕成人| 亚洲日韩视频| 日韩一区欧美二区| 一区在线视频观看| 黄色欧美日韩| 欧美日韩中文一区二区| 久久尤物视频| 精品久久国产一区| 国产精品美女午夜爽爽| 日韩精品视频网站| av成人国产| 野花国产精品入口| 青青国产91久久久久久| 日韩成人精品一区| 久久成人国产| 国产福利一区二区精品秒拍 | 日韩精品一区二区三区免费视频| 粉嫩av一区二区三区四区五区 | а√天堂8资源在线| 国产精品成人自拍| 99久久久久国产精品| 国产精品任我爽爆在线播放 | 麻豆精品在线观看| 91麻豆国产自产在线观看亚洲| 欧美日韩视频| 国产欧美午夜| 欧美另类综合| 成人精品国产亚洲|