如何使用plotly.graph_objs
以类似于plotly.express
的方式绘制熊猫数据-特别是为各种数据类型着色?
基于pandas列中的值对数据类型进行分组的plotly express功能非常有用。不幸的是,我无法在系统中使用express(因为我需要将图形对象发送到orca)
我可以通过将Type
专门映射到颜色(在下面的示例中为full_plot
)来获得相同的功能,但是我有AZ类型,是否有更好的方法来映射数据帧中的每个可能的Type
颜色?
import pandas as pd
import plotly.express as px
import plotly.graph_objs as go
d = {'Scenario': [1, 2, 3, 1, 2,3],
'Type': ["A", "A", "A", "B", "B", "B"],
'VAL_1': [100, 200, 300, 400 , 500, 600],
'VAL_2': [1000, 2000, 3000, 4000, 5000, 6000]}
df = pd.DataFrame(data=d)
def quick_plot(df):
fig = px.bar(df, y='VAL_1', x='Scenario', color="Type", barmode='group')
fig['layout'].update(title = "PX Plot",
width = 600, height = 400,
xaxis = dict(showgrid=False))
fig.show()
def full_plot(df):
colors = {'A': 'blue',
'B': 'red'}
s0=df.query('Type=="A"')
s1=df.query('Type=="B"')
fig = go.Figure()
fig.add_trace(go.Bar(
name='A',
y=s0['VAL_1'],x=s0['Scenario'], marker={'color': colors['A']}))
fig.add_trace(go.Bar(
name='B',
y=s1['VAL_1'],x=s1['Scenario'], marker={'color': colors['B']}))
fig['layout'].update(title = "Full Plot",
width = 600, height = 400)
fig.update_layout(barmode='group')
fig.show()
quick_plot(df)
full_plot(df)
如果我在这里不丢失任何内容,则可以简单地使用这样的字典:
colors = {'A':'steelblue',
'B':'firebrick'}
唯一的挑战在于将每种唯一类型的数据帧分组,并使用for循环为每种类型添加新的跟踪。下面的代码段负责生成该图:
# imports
import pandas as pd
import plotly.express as px
import plotly.graph_objs as go
# data
d = {'Scenario': [1, 2, 3, 1, 2,3],
'Type': ["A", "A", "A", "B", "B", "B"],
'VAL_1': [100, 200, 300, 400 , 500, 600],
'VAL_2': [1000, 2000, 3000, 4000, 5000, 6000]}
df = pd.DataFrame(data=d)
# assign colors to type using a dictionary
colors = {'A':'steelblue',
'B':'firebrick'}
# plotly figure
fig=go.Figure()
for t in df['Type'].unique():
dfp = df[df['Type']==t]
fig.add_traces(go.Bar(x=dfp['Scenario'], y = dfp['VAL_1'], name=t,
marker_color=colors[t]))
fig.show()