[英]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.melt
和DataFrame.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.