行基于图表绘图(Seaborn或Matplotlib)(Row based chart plot (

2019-10-22 20:52发布

鉴于我的数据是大熊猫数据框,看起来像这样:

            Ref   +1    +2    +3    +4    +5    +6    +7  
 2013-05-28  1  -0.44  0.03  0.06 -0.31  0.13  0.56  0.81 
 2013-07-05  2   0.84  1.03  0.96  0.90  1.09  0.59  1.15 
 2013-08-21  3   0.09  0.25  0.06  0.09 -0.09 -0.16  0.56 
 2014-10-15  4   0.35  1.16  1.91  3.44  2.75  1.97  2.16 
 2015-02-09  5   0.09 -0.10 -0.38 -0.69 -0.25 -0.85 -0.47 

我怎样才能绘制5行(1对于每个REF)的图表,其中X轴是列(1,2 ...),并且从0开始? 如果是在seaborn,甚至更好。 但matplotlib解决方案也欢迎。

Answer 1:

在大熊猫绘制数据框一般都约,这样要在各个线路都在单独的列重塑表,而x值是在索引中。 有些重塑操作都有点难看,但你可以这样做:

df = pd.read_clipboard()
plot_table = pd.melt(df.reset_index(), id_vars=['index', 'Ref'])
plot_table = plot_table.pivot(index='variable', columns='Ref', values='value')
# Add extra row to have all lines start from 0:
plot_table.loc['+0', :] = 0
plot_table = plot_table.sort_index()
plot_table
Ref          1     2     3     4     5
variable                              
+0        0.00  0.00  0.00  0.00  0.00
+1       -0.44  0.84  0.09  0.35  0.09
+2        0.03  1.03  0.25  1.16 -0.10
+3        0.06  0.96  0.06  1.91 -0.38
+4       -0.31  0.90  0.09  3.44 -0.69
+5        0.13  1.09 -0.09  2.75 -0.25
+6        0.56  0.59 -0.16  1.97 -0.85
+7        0.81  1.15  0.56  2.16 -0.47

现在,你有正确的形状表格,绘图是相当自动:

plot_table.plot()


文章来源: Row based chart plot (Seaborn or Matplotlib)