如何在 folium 中添加两个 choropleth 图层并使它们像一个特征组一样工作?

pri*_*e90 5 python folium

我创建了两个 choropleth 图层,并将其添加到 folium 中的地图中。但是,我不喜欢图层的功能。首先,即使未选择图层,也会显示两个图例。其次,您必须手动取消选中该复选框才能单独查看第二个分区统计图图层。

我希望图例仅在选择其等值区域图层时显示,并且还允许一次选择一个等值区域图层并且不允许任何重叠。

我查看了文档,发现我认为可行的方法是将等值线图层添加到其中,folium.FeatureGroup()然后将其添加到地图中,但不幸的是,由于某种原因,等值线图层在添加到要素组时会返回错误。

接下来,我遇到了 choropleth 图层的叠加参数。当overlay=False添加到 choropleth 参数中时,我得到一个单选按钮而不是一个复选框,这很棒,但其他图层的图例仍然显示,并且我丢失了地图上的图块。

下面是我的代码。任何有关此事的帮助将不胜感激。谢谢你!

import folium
import pandas as pd
import json

df_theft = pd.read_csv('PA_theft.csv')
df_assualt = pd.read_csv('PA_assualt.csv')

theft_data = json.load(open('theft_geojson.json'))
assualt_data = json.load(open('assualt_geojson.json'))

m = folium.Map(location=[41.20, -77.50], zoom_start=8.3)

theft = folium.Choropleth(
    geo_data=theft_data,
    data=df_theft,               
    columns=['county_name', 'rate'],
    key_on='feature.properties.county_name',
    fill_color='OrRd',
    fill_opacity=0.9,
    legend_name='Theft incident rate per 100,000 people',
    highlight=True,
    name='Theft Incidents',
    show=True
).add_to(m)

folium.GeoJson(
    theft_data,
    tooltip=folium.features.GeoJsonTooltip(fields=['county_name', "arrests", "incident_count",
                                                   "incident_total", "population", "rate" ],
                                                   localize=True)
).add_to(theft.geojson)

assualt = folium.Choropleth(
    geo_data=assualt_data,
    data=df_assualt,               
    columns=['county_name', 'rate'],
    key_on='feature.properties.county_name',
    fill_color='GnBu',
    fill_opacity=0.9,
    legend_name='Assualt incident rate per 100,000 people',
    highlight=True,
    name='Assualt Incidents',
    show=False
).add_to(m)

folium.GeoJson(
    assualt_data,
    tooltip=folium.features.GeoJsonTooltip(fields=['county_name', "arrests", "incident_count",
                                                   "incident_total", "population", "rate" ],
                                                   localize=True)
).add_to(assualt.geojson)

folium.LayerControl(collapsed=False).add_to(m) 
m.save('PA_County_Crime_Map.html')

print('Map created.')
Run Code Online (Sandbox Code Playgroud)