plotly.figure\u factory.create\u注释的\u热图无法正确显示带有轴标签的图形

2024-04-19 11:02:53 发布

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

我想在带有批注的Plotly Dash应用程序中显示批注的热图。如果我没有添加轴标签,或者如果标签不是只有数字的字符串,但是如果我添加了轴标签,那么热图工作得非常好,图太小,注释显示不正确。it works if i added a string to the labels

with labels which i actually want to show

我在Dash中创建了一个简单的示例来说明我的问题

import dash
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
import plotly.express as px
import plotly.graph_objects as go
import plotly.figure_factory as ff
import numpy as np

import pandas as pd

external_stylesheets = ['https://codepen.io/chriddyp/pen/bWLwgP.css']
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
df = pd.read_csv('https://raw.githubusercontent.com/plotly/datasets/master/gapminderDataFiveYear.csv')
app.layout = html.Div([
    dcc.Graph(id='graph-with-slider'),
    dcc.Slider(
        id='year-slider',
        min=df['year'].min(),
        max=df['year'].max(),
        value=df['year'].min(),
        marks={str(year): str(year) for year in df['year'].unique()},
        step=None
    )
])


@app.callback(
    Output('graph-with-slider', 'figure'),
    Input('year-slider', 'value'))
def update_figure(selected_year):
    y = ['8', '9', '10', '11', '12', '13', '14', '15', '16', '17', '18']    
    x = ["023", "034", "045", "056", "067", "078"]
    
    
    z = [[4, 4, 2, 1, 0, 0],
        [0, 0, 0, 0, 0, 0], 
        [11, 2, 4, 0, 0, 1],
        [np.nan, 0, 0, 0, 0, 0], 
        [8, 1, 6, 1, 32, 3], 
        [5, 0, 0, 5, 0, 0],
        [0, 0, 0, 0, 0, 0],
        [24, 2, 15, 1, 0, 5],
        [0, 0, 0, 0, 0, 0], 
        [0, 0, 8, 0, 7, 0],
        [0, 0, 0, 9, 0, 0]]
        
    ## it will work if i enabaled the next two lines of code
    #  or if axis labels where just numbers and not something like "032"
    
    
    #x=["add any non numerical string and it will work" + s  for s in x]
    #y=["add any non numerical string and it will work" + s for s in y]
    

    #fig = go.Figure(data=go.Heatmap(z=z))
    
    fig =ff.create_annotated_heatmap(z=z,x=x,y=y, colorscale  = ["green", "yellow", "orange", "red"], showscale = True)
    
    layout = go.Layout(width=500, height=500,
            hovermode='closest',
            autosize=True,
            xaxis=dict(zeroline=False),
            yaxis=dict(zeroline=False, autorange='reversed')
         )
    fig = go.Figure(data=fig, layout=layout)
  
    
    
    return fig


if __name__ == '__main__':
    app.run_server(debug=True)
    
    
    ```


Tags: importappgodfhtmlasfig标签
2条回答

这是一只虫子。问题出在幕后运行的“_AnnotatedHeatmap”类中(非常确定)。“创建带注释的热图”功能不是一个非常智能的功能。如果你看一下代码,它出人意料地简单(在我看来,它更像是一个快速而肮脏的解决方案,而不是彻底开发的流线型的情节)。我没有费心去解决它,只是四处工作。以下是我的解决方案:

fig = ff.create_annotated_heatmap(z=z,
                                  colorscale='greens')
fig.update_layout(overwrite=True,
                  xaxis=dict(ticks="", dtick=1, side="top", gridcolor="rgb(0, 0, 0)", tickvals=list(range(len(x))), ticktext=x)
                  yaxis=dict(ticks="", dtick=1, ticksuffix="   ", tickvals=list(range(len(y))), ticktext=y))
fig.show()

这种解决方法的问题是,内置的数据到轴映射不会发生。你必须自己映射数据确保对轴进行排序,并将数据也按这种方式排序我还没有验证它是否正确映射了数据,但我认为确实如此。为了缓解这个问题,下面是我为此编写的代码:

x = list(sorted(df['X'].unique().tolist()))
y = list(sorted(df['Y'].unique().tolist()))

z = list()
iter_list = list()
for y_item in y:
    iter_list.clear()
    for x_item in x:
        z_data_point = df[(df['X'] == x_item) & (df['Y'] == y_item)]['Z']
        iter_list.append(0 if len(z_data_point) == 0 else z_data_point.iloc[0])
    z.append([_ for _ in iter_list])

清澈如泥?希望我打对了。如果没有,请在评论中告诉我。我相信这最后一段代码是可以改进的,所以如果你知道怎么做的话,请随意在评论中留下它,我会更新它

我无法复制您的确切问题,但我看到了类似的问题

尝试: 图更新_xaxes(type='category')

Plotly在后台做一些工作,如果它认为它可以迫使你的轴“线性”。类型标签可能会避免这种情况

这里有一些背景 Plotly Categorical Axes

相关问题 更多 >