繁体   English   中英

重塑数据框以显示排名的变化

[英]reshape a data frame to show the change of ranking

         2010 2011 2012
     1   a    b   c 
     2   b    c   a
     3   c    a   b

假设我有一个如上所述的数据框,索引是排名(2010年排名第一)。 我想重塑数据框,比如

    2010 2011 2012
a    1     3    2
b    2     1    3
c

这样价值就成了排名。 我怎样才能做到这一点?

如果每行可以使用唯一值,请使用DataFrame.meltDataFrame.pivot

df = df.reset_index().melt('index').pivot('value','variable','index')
print (df)
variable  2010  2011  2012
value                     
a          1.0   3.0   2.0
b          2.0   1.0   3.0
c          3.0   2.0   1.0

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM