Pandas_规整数据_转换数据_stack() unstack()2

转换数据

df.stack() 列索引→行索引    df.unstack() 行索引→列索引

参数类型说明
level

int

string

list

-1 默认值

默认将最内层的行索引转换为最内层的列索引

fill_valuevaluereplace NaN with this value if the unstack produces missing values
>>> df
one  a   1.0
     b   2.0
two  a   3.0
     b   4.0

# 如果索引是多重的,可以指定"压缩"哪一层的索引
# - 行索引,从0开始,最左边最小为0
# - 列索引,从0开始,最上边最小为0
# 也可以不用0和1..等,用索引层的名字
# 数字和名字但不能混用,但是可以同时指定多个level值
# 摘自 weijian001 的CSDN 博客

>>> df.unstack() / df.unstack(level=-1) / df.unstack(level=1)
     a   b
one  1.0  2.0
two  3.0  4.0

>>> df.unstack(level=0)
	one	two
a	1.0	3.0
b	2.0	4.0

#这个不太懂哎 o(╥﹏╥)o
#只有一个行索引的情况时,返回一个Series对象
>>> df1
	one	two
a	1.0	3.0
b	2.0	4.0

>>> df1.unstack()
one  a  1.0
     b  2.0
two  a  3.0
     b  4.0

>>> df2
A	weight	height
B	kg	m
cat	1.0	2.0
dog	3.0	4.0

>>> df2.unstack()
A       B      
weight  kg  cat    1.0
            dog    3.0
height  m   cat    2.0
            dog    4.0

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值