gpt4 book ai didi

python-3.x - 有没有办法在全息图桑基图中过滤维度

转载 作者:行者123 更新时间:2023-12-04 15:37:19 24 4
gpt4 key购买 nike

我试图在 Holoviews 中显示从 Sankey 图表中的位置迁移,但我找不到添加下拉式过滤器的方法。我不允许列出比我正在绘制的更多的关键维度,我希望它能工作,因为我在其他 HoloViews 元素中获得下拉菜单,因为它会自动按我所做的所有关键维度对我的数据进行分组 not 分配给元素。

import pandas as pd
import numpy as np
import holoviews as hv
from holoviews import opts

hv.extension('bokeh')

df = pd.DataFrame({'from': ["a", "b", "c", "a", "b", "c"],
'to': ["d", "d", "e", "e", "e", "d"],
'number': [10, 2, 1, 8, 2, 2],
'year': [2018, 2018, 2018, 2017, 2017, 2017]})
df

from to number year
0 a d 10 2018
1 b d 2 2018
2 c e 1 2018
3 a e 8 2017
4 b e 2 2017
5 c d 2 2017

现在 Holoviews 将年份列添加到 kdims,因为我希望下拉列表按年份过滤:

kdims = ["from", "to", "year"]
vdims = ["number"]

sankey = hv.Sankey(df, kdims=kdims, vdims=vdims)
sankey.opts(label_position='left', edge_color='to', node_padding=30, node_color='number', cmap='tab20')

返回:

ValueError: kdims: list length must be between 2 and 2 (inclusive)

如果没有第三个关键维度,桑基图会按预期工作,但没有交互式过滤器: enter image description here

最佳答案

这里有 2 种方法可以解决您的问题:

1) 将您的数据框转换为全息 View 数据集并将其转换为桑基图:
由于“年”位于第三个关键维度下方的代码中,因此它将用作 slider 的维度。前 2 个变量('from' 和 'to')将用作 Sankey 图的关键 dims。

hv_ds = hv.Dataset(
data=df,
kdims=['from', 'to', 'year'],
vdims=['number'],
)

hv_ds.to(hv.Sankey)


2) 或者,每年创建一个包含 Sankey 图的字典,并将它们放入全息图中:

sankey_dict = {
year: hv.Sankey(df[df.year == year])
for year in df.year.unique()
}

holo = hv.HoloMap(sankey_dict, kdims='year')


两种解决方案都会创建全息图:
http://holoviews.org/reference/containers/bokeh/HoloMap.html


结果图 + slider : holomap sankey slider


我测试过这个:
hvplot 0.5.2
holoviews 1.12.5 和 holoviews 1.13
jupyterlab 1.2.4

关于python-3.x - 有没有办法在全息图桑基图中过滤维度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59338762/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com