How to convert column names to column values ​​in pandas - python

df=pd.DataFrame(index=['x','y'], data={'a':[1,2],'b':[3,4]})

how can i convert column names to column values? This is my desired result.

   c1  c2
x  1   a
x  3   b
y  2   a
y  4   b
+4
source share
4 answers

You can use:

print (df.T.unstack().reset_index(level=1, name='c1')
                     .rename(columns={'level_1':'c2'})[['c1','c2']])
   c1 c2
x   1  a
x   3  b
y   2  a
y   4  b

Or:

print (df.stack().reset_index(level=1, name='c1')
                 .rename(columns={'level_1':'c2'})[['c1','c2']])
   c1 c2
x   1  a
x   3  b
y   2  a
y   4  b
+2
source

try the following:

In [279]: df.stack().reset_index().set_index('level_0').rename(columns={'level_1':'c2',0:'c1'})
Out[279]:
        c2  c1
level_0
x        a   1
x        b   3
y        a   2
y        b   4
+3
source
In [62]: (pd.melt(df.reset_index(), var_name='c2', value_name='c1', id_vars='index')
          .set_index('index'))
Out[62]: 
      c2  c1
index       
x      a   1
y      a   2
x      b   3
y      b   4
+2
source

Try:

df1 = df.stack().reset_index(-1).iloc[:, ::-1]
df1.columns = ['c1', 'c2']
df1

enter image description here

+1
source

All Articles