GeoJSON popup and tooltip#

[2]:
import pandas as pd


income = pd.read_csv(
    "https://raw.githubusercontent.com/pri-data/50-states/master/data/income-counties-states-national.csv",
    dtype={"fips": str},
)
income["income-2015"] = pd.to_numeric(income["income-2015"], errors="coerce")
[3]:
income.head()
[3]:
fips county state income-2015 income-1989a income-1989b change
0 00000 US US 55775.0 28906 53367.28102 4.316843
1 01000 Alabama AL 44833.0 22202 40990.11877 8.571546
2 01001 Autauga County AL 56580.0 26898 49660.04030 12.230399
3 01003 Baldwin County AL 52387.0 24043 44389.03818 15.267074
4 01005 Barbour County AL 31433.0 18673 34474.75398 -9.676945
[4]:
import geopandas
import requests

data = requests.get(
    "https://raw.githubusercontent.com/python-visualization/folium-example-data/main/us_states.json"
).json()
states = geopandas.GeoDataFrame.from_features(data, crs="EPSG:4326")

states.head()
[4]:
geometry name
0 POLYGON ((-87.35930 35.00118, -85.60667 34.984... Alabama
1 MULTIPOLYGON (((-131.60202 55.11798, -131.5691... Alaska
2 POLYGON ((-109.04250 37.00026, -109.04798 31.3... Arizona
3 POLYGON ((-94.47384 36.50186, -90.15254 36.496... Arkansas
4 POLYGON ((-123.23326 42.00619, -122.37885 42.0... California
[5]:
import requests

response = requests.get(
    "https://gist.githubusercontent.com/tvpmb/4734703/raw/"
    "b54d03154c339ed3047c66fefcece4727dfc931a/US%2520State%2520List"
)
abbrs = pd.read_json(response.text)

abbrs.head(3)
/tmp/ipykernel_4582/3509232749.py:7: FutureWarning: Passing literal json to 'read_json' is deprecated and will be removed in a future version. To read from a literal string, wrap it in a 'StringIO' object.
  abbrs = pd.read_json(response.text)
[5]:
name alpha-2
0 Alabama AL
1 Alaska AK
2 Arizona AZ
[6]:
statesmerge = states.merge(abbrs, how="left", left_on="name", right_on="name")
statesmerge["geometry"] = statesmerge.geometry.simplify(0.05)

statesmerge.head()
[6]:
geometry name alpha-2
0 POLYGON ((-88.20274 34.99570, -85.60667 34.984... Alabama AL
1 MULTIPOLYGON (((-131.64584 55.03583, -131.5691... Alaska AK
2 POLYGON ((-109.04250 37.00026, -109.04798 31.3... Arizona AZ
3 POLYGON ((-94.61624 36.50186, -90.15254 36.496... Arkansas AR
4 POLYGON ((-124.21363 42.00071, -120.00186 41.9... California CA
[7]:
income.groupby("state")["income-2015"].median().head()
[7]:
state
AK    62561.5
AL    38721.5
AR    37890.0
AZ    43810.0
CA    53341.0
Name: income-2015, dtype: float64
[8]:
statesmerge["medianincome"] = statesmerge.merge(
    income.groupby("state")["income-2015"].median(),
    how="left",
    left_on="alpha-2",
    right_on="state",
)["income-2015"]
statesmerge["change"] = statesmerge.merge(
    income.groupby("state")["change"].median(),
    how="left",
    left_on="alpha-2",
    right_on="state",
)["change"]
[9]:
statesmerge.head()
[9]:
geometry name alpha-2 medianincome change
0 POLYGON ((-88.20274 34.99570, -85.60667 34.984... Alabama AL 38721.5 2.779114
1 MULTIPOLYGON (((-131.64584 55.03583, -131.5691... Alaska AK 62561.5 14.758367
2 POLYGON ((-109.04250 37.00026, -109.04798 31.3... Arizona AZ 43810.0 NaN
3 POLYGON ((-94.61624 36.50186, -90.15254 36.496... Arkansas AR 37890.0 10.897394
4 POLYGON ((-124.21363 42.00071, -120.00186 41.9... California CA 53341.0 6.716596
[10]:
statesmerge["medianincome"].quantile(0.25)
[10]:
43969.375
[11]:
import branca


colormap = branca.colormap.LinearColormap(
    vmin=statesmerge["change"].quantile(0.0),
    vmax=statesmerge["change"].quantile(1),
    colors=["red", "orange", "lightblue", "green", "darkgreen"],
    caption="State Level Median County Household Income (%)",
)
[12]:
m = folium.Map(location=[35.3, -97.6], zoom_start=4)

popup = folium.GeoJsonPopup(
    fields=["name", "change"],
    aliases=["State", "% Change"],
    localize=True,
    labels=True,
    style="background-color: yellow;",
)

tooltip = folium.GeoJsonTooltip(
    fields=["name", "medianincome", "change"],
    aliases=["State:", "2015 Median Income(USD):", "Median % Change:"],
    localize=True,
    sticky=False,
    labels=True,
    style="""
        background-color: #F0EFEF;
        border: 2px solid black;
        border-radius: 3px;
        box-shadow: 3px;
    """,
    max_width=800,
)


g = folium.GeoJson(
    statesmerge,
    style_function=lambda x: {
        "fillColor": colormap(x["properties"]["change"])
        if x["properties"]["change"] is not None
        else "transparent",
        "color": "black",
        "fillOpacity": 0.4,
    },
    tooltip=tooltip,
    popup=popup,
).add_to(m)

colormap.add_to(m)

m
[12]:
Make this Notebook Trusted to load map: File -> Trust Notebook