0

到目前为止,一切正常。我创建了一个新文件来创建新的热图。我的数据框如下所示:

time                     name      lng     lat
2019-10-16 08:00:00       A      23.1113   34.123123
2019-10-16 09:00:00       B      12.1113   11.123123
2019-10-16 07:30:00       C      134.1113   12.123123
2019-10-16 08:40:00       D      122.1113   12.123123
2019-10-16 08:50:00       A      16.1113   12.123123

这始终与我之前在创建热图确切名称和其他列时使用的数据框完全相同。

复制粘贴之前创建热图的代码:

layer = pdk.Layer(
    "HeatmapLayer",
    df,
    get_position="[lng, lat]"
) 
center = [126.986, 37.565] 
view_state = pdk.ViewState( 
    longitude=center[0], 
    latitude=center[1],
    zoom=10
)
r = pdk.Deck(layers=[layer],
             initial_view_state=view_state,
             mapbox_key=MAPBOX_API_KEY)
r.show()

当我运行 w/o r.show() 它不显示任何东西,当我运行 r.show() 它输出TypeError: vars() argument must have __dict__ attribute

我无法弄清楚出了什么问题......

4

6 回答 6

2

它发生在我身上,解决方案只传递给 pydeck 所需的列。在您的情况下 df[["lng", "lat"]] 这可能是与熊猫数据框任何列中的任何 N/A 值相关的问题,但我不确定。

于 2020-04-29T11:00:47.473 回答
1

这个问题有点老了。但是对于那些可能在更新版本的 pydeck 中遇到这个问题的人来说,在我的情况下,这是因为以下论点:

latitude=center_lat, longitude=center_lng

pdk.ViewState函数的不是浮点数而是np.float32变量。一个简单的演员,如float(center_lat)工作。

于 2021-09-15T09:03:15.020 回答
1

您可以使用r.to_html()而不是解决它r.show()

于 2020-07-06T14:05:09.217 回答
0

我遇到了同样的问题,我怀疑pydeck你的 df 列之一可能不满意time。您是否使用 numpy 在此列中创建了数据?就我而言,一个简单的 np 函数:

color = np.random.choice(range(256), size=3)

提出了同样的问题。我解决它的方法是添加.tolist(),因此它将转换为普通列表/数组。之后,将它传递给 pydeck 作为color道具效果很好。

我的建议是回到您创建此专栏的位置,并尝试为 pydeck“简化”它。Ghirardi 的回答也是正确的,但会迫使您删除可能在渲染过程中以某种方式使用的数据(即颜色time等)

于 2020-08-10T18:43:12.197 回答
0

我正在发送 np 数组

grouped_df.apply(lambda x: list(x[[LON, LAT]].values))

哪个搞乱了 json 转换。他们需要是列表:

grouped_df.apply(lambda x: list(x[[LON, LAT]].values.tolist()))
于 2021-11-17T09:26:10.530 回答
0

我在尝试绘制 H3HexagonLayer 时遇到了类似的问题。由于提供的解决方案都不适合我,因此它遵循了解决我的问题的方法。

我刚刚将原始数据框 df 替换为:

df = pd.read_json(df.to_json())

一个好处是我不需要将列限制为明确使用的列。此外,deck.show() 和 deck.to_html() 也可以正常工作。

于 2021-11-18T18:54:20.620 回答