ファイルをループする必要があります。以下のファイルは、緯度、経度、標高の 3 つの列を持つ単純なファイルです。
この形式で単純なテキスト ファイルを作成すると、このコードはファイルをループして追加します。緯度、経度、標高を持つ列を取得し、ポップアップで動的ポップアップを作成します。
data = pandas.read_csv("Volcanoes.txt")
lat = list(data["LAT"])
lon = list(data["LON"])
elev = list(data["ELEV"])
# make a color code for elevation
def color_producer(elevation):
if elevation < 1000:
return 'green'
elif 1000 <= elevation < 3000:
return 'orange'
else:
return 'red'
# set the base map
map = folium.Map(location=[47.0, -122.5], zoom_start=12)
# add an additional tile layer
map.add_tile_layer("Stamen Toner")
fgv = folium.FeatureGroup(name="Volcanoes")
# loop through and plot everything
for lt, ln, el in zip(lat, lon, elev):
fgv.add_child(folium.CircleMarker(location=[lt, ln], radius = 6, popup=str(el)+" m",
fill_color=color_producer(el), fill=True, color = 'grey', fill_opacity=0.7))
fgp = folium.FeatureGroup(name="Population")
# add a map of shading by population
fgp.add_child(folium.GeoJson(data=open('world.json', 'r', encoding='utf-8-sig').read(),
style_function=lambda x: {'fillColor':'green' if x['properties']['POP2005'] < 10000000
else 'orange' if 10000000 <= x['properties']['POP2005'] < 20000000 else 'red'}))
# add the layers
map.add_child(fgv)
map.add_child(fgp)
map.add_child(folium.LayerControl())