首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Holoviews显示额外行?

Holoviews显示额外行?
EN

Stack Overflow用户
提问于 2020-01-06 09:53:15
回答 1查看 920关注 0票数 5

我有一个数据集,其中我想用X轴上的两个不同变量绘制图(在两个不同的图中),但是我想把另一个值放到have工具中。

代码语言:javascript
复制
from io import StringIO
import pandas as pd

data = """,item_id,start,station,rejects
0,item1,2019-10-14 19:00:00,assembly,4.297994269340974
1,item1,2019-10-14 19:00:00,ST1,0.20546537908362442
2,item1,2019-10-14 19:00:00,ST2,0.494539460127756
3,item1,2019-10-14 19:00:00,ST3,0.6892230576441103
4,item2,2019-10-14 23:30:00,assembly,4.432249894470241
5,item2,2019-10-14 23:30:00,ST1,0.19071837253655435
6,item2,2019-10-14 23:30:00,ST2,0.7651434643995749
7,item2,2019-10-14 23:30:00,ST3,0.7748600947051227
8,item3,2019-10-15 04:00:00,assembly,3.55576079427384
9,item3,2019-10-15 04:00:00,ST1,0.37002775208140615
10,item3,2019-10-19 04:00:00,ST2,0.7195914577530177
11,item3,2019-10-19 04:00:00,ST3,0.492379835873388
12,item4,2019-10-19 10:30:00,assembly,4.02656704026567
13,item4,2019-10-19 10:30:00,ST1,0.22926219258024177
14,item4,2019-10-19 10:30:00,ST2,0.690376569037657
15,item4,2019-10-19 10:30:00,ST3,0.838745695410320"""

data_reduced = pd.read_csv(StringIO(data), parse_dates=["start"], index_col=0)

我想用x轴上的item_id和x轴上的start日期生成一个图形。我想跟踪每个站的废品,以及总成的组合。

代码语言:javascript
复制
import holoviews as hv
import bokeh
from holoviews import opts
hv.extension('bokeh')
bokeh.plotting.output_notebook()

def plot(data_reduced, x_axis="item_id"):
    x_label = x_axis if x_axis in {"start", "item_id"} else "item_id"
    key_dimensions = [(x_label, x_label), ("station", "station")]
    value_dimensions = [
        ("rejects", "rejects"),
        ("start", "start"),
        ("item_id", "item_id"),
        ("start", "start"),
    ]

    datatable = hv.Table(
        data_reduced, kdims=key_dimensions, vdims=value_dimensions
    )
    scatter_plot = datatable.to.scatter(x_label, ["rejects"])
    overlay = scatter_plot.overlay("station")

    tooltips = [
        ("item_id", "@item_id"),
        ("start", "@start{%Y-%m-%d %H:%M}"),
        ("station", "@station"),
        ("rejects", "@rejects"),
    ]
    hover = bokeh.models.HoverTool(
        tooltips=tooltips, formatters={"start": "datetime"}
    )

    return overlay.opts(
        opts.Scatter(
            color=hv.Cycle("Category10"),
            show_grid=True,
            padding=0.1,
            height=400,
            tools=[hover],
        ),
        opts.NdOverlay(
            legend_position="right", show_frame=False, xrotation=90
        ),
    )

然后用plot(data_reduced, x_axis="start")plot(data_reduced, x_axis="item_id")绘制图形

情节(data_reduced,x_axis="start")

地块(data_reduced,x_axis="item_id")

如何填写???

如果我想从一个单独的行(list(p.items())[0][1].data)获取数据,我得到:

代码语言:javascript
复制
,item_id,start,station,rejects
1,item1,2019-10-14 19:00:00,ST1,0.2054653790836244
5,item2,2019-10-14 23:30:00,ST1,0.19071837253655435
9,item3,2019-10-15 04:00:00,ST1,0.37002775208140615
13,item4,2019-10-19 10:30:00,ST1,0.22926219258024175

所以数据似乎在源中

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2020-01-08 10:03:25

在这种情况下,我更喜欢使用赫夫图特,它是一个建立在全息视图之上的库,由同一组开发人员创建。这真的使生活变得简单多了,创造了你的情节,一蹴而就。

( 1)使用Hvplot,您可以很容易地使用关键字悬停_cols=‘you _column’指定额外的悬停列。

代码语言:javascript
复制
# with this import you can use .hvplot() on your df and create interactive holoviews plots
import hvplot.pandas

item_plot = data_reduced.hvplot(
    kind='scatter',
    x='item_id',
    y='rejects',
    by='station',  # this creates the overlay
    hover_cols=['start'],
    padding=0.1,
)

start_plot = data_reduced.hvplot(
    kind='scatter',
    x='start',
    y='rejects',
    by='station',
    hover_cols=['item_id'],
    padding=0.1,
)

2)如果您想要一个纯全息视图解决方案,可以这样做:

代码语言:javascript
复制
import holoviews as hv
from holoviews import opts

hv_df = hv.Dataset(
    data_reduced,
    kdims=['item_id', 'station'], 
    vdims=['rejects', 'start'],
)

hv_df.to(hv.Scatter).overlay().opts(opts.Scatter(tools=['hover']))

带有额外悬停列的示例绘图:

票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59609911

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档