将 DataFrame 从行重塑为列

Reshape DataFrame from rows to columns

我有一个 pandas 数据框,如下所示:

id, value
1, a
2, b
3, c
.
.
1000, fsdf

我想将其转换成类似下面的形式

id1, value1, id2, value2, ...... id5, value5
1,    a,      2,       b,          5,      e
6    
.
.
995,  .  .........................1000,    fsdf

有什么方法可以用 pandas 做到这一点吗?

您可以使用 numpy.reshape with shape:

print df
   id value
0   1     a
1   2     b
2   3     c
3   4     d
4   5     e
5   6     f
6   7     g
7   8     h
8   9     i
9  10     j

print df.shape
(10, 2)

print df.values.reshape(df.shape[0] / 5, 10)
[[1L 'a' 2L 'b' 3L 'c' 4L 'd' 5L 'e']
 [6L 'f' 7L 'g' 8L 'h' 9L 'i' 10L 'j']]

#see 
cols = ['{}{}'.format(x, y) for y in range(1, 6) for x in df.columns]
print cols
['id1', 'value1', 'id2', 'value2', 'id3', 'value3', 'id4', 'value4', 'id5', 'value5']

df = pd.DataFrame(df.values.reshape(df.shape[0] / 5, 10), columns=cols)
print df
  id1 value1 id2 value2 id3 value3 id4 value4 id5 value5
0   1      a   2      b   3      c   4      d   5      e
1   6      f   7      g   8      h   9      i  10      j