为什么python中的choropleth映射是空的?

2024-05-29 02:51:17 发布

您现在位置:Python中文网/ 问答频道 /正文

所以我在努力学习绘制choropleth地图。我使用了一个示例数据集,但结果是空的。请你看看它,告诉我出了什么问题,因为我已经反复检查了语法,不明白它为什么不显示我的数据。我包含了数据集头和我编写的代码,如下所示: screenshot of datahead

datia = dict(type = 'choropleth',
            locations = df['Names'],
            locationmode = 'USA-states',
            colorscale= 'Portland',
            text= df['Names'],
            z=df['2010-11'],
            colorbar = {'title':'Vaccine Coverage in percentage'})
layout = dict(title = 'Vaccine Coverage in percentage',
              geo = {'scope':'usa'})
choromap = go.Figure(data = [datia],layout = layout)
iplot(choromap, validate=False)

myemptymap


Tags: 数据indfnamestitlecoverage地图绘制
1条回答
网友
1楼 · 发布于 2024-05-29 02:51:17

你需要给州缩写(DC,AL,…)而不是名字。 我也面临同样的问题。在改变这一点之后,它起作用了。 可以使用以下代码将名称转换为缩写

def convert_state_name(name):
    cd=str(name)
    us_state_abbrev = {
    "Alabama":"AL"
    "Alaska":"AK"
    "Arizona":"AZ"
    "Arkansas":"AR"
    "California":"CA"
    "Colorado":"CO"
    "Connecticut":"CT"
    "Delaware":"DE"
    "Washington DC":"DC"
    "Florida":"FL"
    "Georgia":"GA"
    "Hawaii":"HI"
    "Idaho":"ID"
    "Illinois":"IL"
    "Indiana":"IN"
    "Iowa":"IA"
    "Kansas":"KS"
    "Kentucky":"KY"
    "Louisiana":"LA"
    "Maine":"ME"
    "Maryland":"MD"
    "Massachusetts":"MA"
    "Michigan":"MI"
    "Minnesota":"MN"
    "Mississippi":"MS"
    "Missouri":"MO"
    "Montana":"MT"
    "Nebraska":"NE"
    "Nevada":"NV"
    "New Hampshire":"NH"
    "New Jersey":"NJ"
    "New Mexico":"NM"
    "New York":"NY"
    "North Carolina":"NC"
    "North Dakota":"ND"
    "Ohio":"OH"
    "Oklahoma":"OK"
    "Oregon":"OR"
    "Pennsylvania":"PA"
    "Rhode Island":"RI"
    "South Carolina":"SC"
    "South Dakota":"SD"
    "Tennessee":"TN"
    "Texas":"TX"
    "Utah":"UT"
    "Vermont":"VT"
    "Virginia":"VA"
    "Washington":"WA"
    "West Virginia":"WV"
    "Wisconsin":"WI"
    "Wyoming":"WY"
    return us_state_abbrev[cd]

df['STATE_CD'] = df.Names.apply(lambda x:convert_state_name(x)) 

最后,您可以将locations=df['Names']替换为locations=df['STATE\u CD']

希望这有帮助。在

相关问题 更多 >

    热门问题