sách gpt4 ăn đã đi

python - dữ liệu chiều dài/chiều rộng thành chiều rộng/dài

In lại 作者:太空狗 更新时间:2023-10-29 22:28:34 27 4
mua khóa gpt4 giày nike

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

nhập pandas dưới dạng pd
d = {'decil': ['1. decil','1. decil','2. decil','2. decil','3. decil','3. decil'],
'kommune': ['AA','BB','AA','BB','AA','BB'],'2010':[44,25,242,423,845,962],
'2011':[64,26,239,620,862,862]}
df = pd.DataFrame(data=d)

打印

decil kommune 2010 2011
1. decil AA 44 64
1. decil BB 25 26
2. decil AA 242 239
2. decil BB 423 620
3. decil AA 845 862
3. decil BB 962 862

我想要的输出是这样的

 kommune year 1. decil 2. decil 3. decil
AA 2010 44 242 845
AA 2011 64 239 862
BB 2010 25 423 962
BB 2011 25 620 862

也就是说,我正在寻找一种方法来将“decil”列从长格式更改为宽格式,同时将年份列从宽格式更改为长格式。我已经尝试过 pd.pivot_table、循环和 unstack,但没有任何运气。有什么聪明的方法吗?预先感谢您的帮助。

câu trả lời hay nhất

sử dụngset_indexstackunstack :

df = (df.set_index(['decil','kommune'])
.stack()
.unstack(0)
.reset_index()
.rename_axis(None, axis=1))

print (df)
kommune level_1 1. decil 2. decil 3. decil
0 AA 2010 44 242 845
1 AA 2011 64 239 862
2 BB 2010 25 423 962
3 BB 2011 26 620 862

关于python - 长/宽数据到宽/长,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/52534500/

27 4 0
Chứng chỉ ICP Bắc Kinh số 000000
Hợp tác quảng cáo: 1813099741@qq.com 6ren.com
Xem sitemap của VNExpress