Python--pandas--unstack() 與stack()

概述

  • Python的pandas庫是我們經(jīng)常用到的庫之一昆咽,不可避免地會(huì)應(yīng)用到數(shù)據(jù)的reshape。其中蓖捶,stack和unstack是我們經(jīng)常用到的操作之一剑逃。很多人對這2個(gè)操作比較迷惑。

  • stack和unstack是python進(jìn)行層次化索引的重要操作稍坯。層次化索引就是對索引進(jìn)行層次化分類酬荞,便于使用,這里的索引可以是行索引瞧哟,也可以是列索引混巧。

  • 常見的數(shù)據(jù)的層次化結(jié)構(gòu)有兩種,一種是表格勤揩,一種是“花括號(hào)”咧党,即下面這樣的兩種形式:


    表格格式

    花括號(hào)格式.png
  • 表格在行列方向上均有索引,花括號(hào)結(jié)構(gòu)只有“列方向”上的索引陨亡。

  • 其實(shí)傍衡,應(yīng)用stack和unstack只需要記住下面的知識(shí)點(diǎn)即可:

    • stack: 將數(shù)據(jù)從”表格結(jié)構(gòu)“變成”花括號(hào)結(jié)構(gòu)“,即將其列索引變成行索引负蠕。
    • unstack: 數(shù)據(jù)從”花括號(hào)結(jié)構(gòu)“變成”表格結(jié)構(gòu)“蛙埂,即要將其中一層的行索引變成列索引。如果是多層索引遮糖,則以上函數(shù)是針對內(nèi)層索引(這里是store)箱残。利用level可以選擇具體哪層索引。

入門級demo

#!/usr/bin/python3
# -*- coding: utf-8 -*-
# @Time    : 2019-06-12 23:48
# @Author  : LiYahui
# @Description :  stack demo
import pandas as pd
import numpy as np
from pandas import Series,DataFrame
data=DataFrame(np.arange(12).reshape((3,4)),index=pd.Index(['street1','street2','street3']),
               columns=pd.Index(['store1','store2','store3','store4']))
print('----------data--------')
print(data)
print('-------------data2----------------------------\n')
data2=data.stack()
data3=data2.unstack()
print(data2)
print('--------------data3---------------------------\n')
print(data3)

data4=data2.unstack(level=0)
print('-------data4----------')
print(data4)
data5=data2.unstack(level=-1) # 默認(rèn)的level=-1止吁,內(nèi)層的索引
print('------data5--------')
print(data5)
'''
----------data--------
         store1  store2  store3  store4
street1       0       1       2       3
street2       4       5       6       7
street3       8       9      10      11
-------------data2----------------------------

street1  store1     0
         store2     1
         store3     2
         store4     3
street2  store1     4
         store2     5
         store3     6
         store4     7
street3  store1     8
         store2     9
         store3    10
         store4    11
dtype: int64
--------------data3---------------------------

         store1  store2  store3  store4
street1       0       1       2       3
street2       4       5       6       7
street3       8       9      10      11
-------data4----------
        street1  street2  street3
store1        0        4        8
store2        1        5        9
store3        2        6       10
store4        3        7       11
------data5--------
         store1  store2  store3  store4
street1       0       1       2       3
street2       4       5       6       7
street3       8       9      10      11
'''
  • 可以看到:使用stack函數(shù)被辑,將data的列索引['store1','store2','store3’,'store4']轉(zhuǎn)變成行索引(第二層),便得到了一個(gè)層次化的Series(data2)敬惦,使用unstack函數(shù)盼理,將data2的第二層行索引轉(zhuǎn)變成列索引(默認(rèn)內(nèi)層索引,level=-1)俄删,便又得到了DataFrame(data3)
  • 下面的例子我們利用level選擇具體哪層索引宏怔。

data4=data2.unstack(level=0)
print(data4)
'''
        street1  street2  street3
store1        0        4        8
store2        1        5        9
store3        2        6       10
store4        3        7       11
'''
  • 我們可以清晰看到奏路,當(dāng)我們?nèi)evel=0時(shí),即最外層索引時(shí)臊诊,unstack把行索引['street1','street2','street3’]變?yōu)榱肆兴饕?/li>

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末鸽粉,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子抓艳,更是在濱河造成了極大的恐慌触机,老刑警劉巖,帶你破解...
    沈念sama閱讀 206,214評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件玷或,死亡現(xiàn)場離奇詭異儡首,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)偏友,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,307評論 2 382
  • 文/潘曉璐 我一進(jìn)店門蔬胯,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人位他,你說我怎么就攤上這事氛濒。” “怎么了鹅髓?”我有些...
    開封第一講書人閱讀 152,543評論 0 341
  • 文/不壞的土叔 我叫張陵舞竿,是天一觀的道長。 經(jīng)常有香客問我迈勋,道長炬灭,這世上最難降的妖魔是什么醋粟? 我笑而不...
    開封第一講書人閱讀 55,221評論 1 279
  • 正文 為了忘掉前任靡菇,我火速辦了婚禮,結(jié)果婚禮上米愿,老公的妹妹穿的比我還像新娘厦凤。我一直安慰自己,他們只是感情好育苟,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,224評論 5 371
  • 文/花漫 我一把揭開白布较鼓。 她就那樣靜靜地躺著,像睡著了一般违柏。 火紅的嫁衣襯著肌膚如雪博烂。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 49,007評論 1 284
  • 那天漱竖,我揣著相機(jī)與錄音禽篱,去河邊找鬼。 笑死馍惹,一個(gè)胖子當(dāng)著我的面吹牛躺率,可吹牛的內(nèi)容都是我干的玛界。 我是一名探鬼主播,決...
    沈念sama閱讀 38,313評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼悼吱,長吁一口氣:“原來是場噩夢啊……” “哼慎框!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起后添,我...
    開封第一講書人閱讀 36,956評論 0 259
  • 序言:老撾萬榮一對情侶失蹤笨枯,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后吕朵,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體猎醇,經(jīng)...
    沈念sama閱讀 43,441評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 35,925評論 2 323
  • 正文 我和宋清朗相戀三年努溃,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了硫嘶。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,018評論 1 333
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡梧税,死狀恐怖沦疾,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情第队,我是刑警寧澤哮塞,帶...
    沈念sama閱讀 33,685評論 4 322
  • 正文 年R本政府宣布,位于F島的核電站凳谦,受9級特大地震影響忆畅,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜尸执,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,234評論 3 307
  • 文/蒙蒙 一家凯、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧如失,春花似錦绊诲、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,240評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至脆丁,卻和暖如春世舰,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背槽卫。 一陣腳步聲響...
    開封第一講書人閱讀 31,464評論 1 261
  • 我被黑心中介騙來泰國打工跟压, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人晒夹。 一個(gè)月前我還...
    沈念sama閱讀 45,467評論 2 352
  • 正文 我出身青樓裆馒,卻偏偏與公主長得像姊氓,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子喷好,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,762評論 2 345

推薦閱讀更多精彩內(nèi)容