Python學(xué)習(xí)筆記(9):Series和DataFrame的算術(shù)運(yùn)算

Pandas的一個(gè)最重要的功能是途凫,可以對(duì)不同索引的對(duì)象進(jìn)行數(shù)據(jù)運(yùn)算危纫。

1、兩個(gè)Series對(duì)象的運(yùn)算

相同索引上的元素直接相加掰派,索引不同的元素默認(rèn)為NA值从诲。

import pandas as pd
import numpy as np
from pandas import Series, DataFrame
s1 = Series([7.3, -2.5, 3.4, 1.5], index = ['a', 'c', 'd', 'e'])
s2 = Series([-2.1, 3.6, -1.5, 4, 3.1], index = ['a', 'c', 'e', 'f', 'g'])
s1 + s2
輸出:
a    5.2
c    1.1
d    NaN
e    0.0
f    NaN
g    NaN
dtype: float64

2、兩個(gè)DataFrame對(duì)象的運(yùn)算

相同索引及相同列上的元素直接相加靡羡,索引或列不同的元素默認(rèn)為NA值系洛。

df1 = DataFrame(np.arange(9).reshape((3, 3)), columns = list('bcd'), index = ['Ohio', 'Texas', 'Colorado'])
df2 = DataFrame(np.arange(12).reshape((4, 3)), columns = list('bde'), index =  ['Utah', 'Ohio', 'Texas', 'Oregon'])
df1 + df2
輸出:
    b   c   d   e
Colorado    NaN NaN NaN NaN
Ohio    3.0 NaN 6.0 NaN
Oregon  NaN NaN NaN NaN
Texas   9.0 NaN 12.0    NaN
Utah    NaN NaN NaN NaN

3、在算數(shù)運(yùn)算時(shí)填充值

看上面的一大片NaN略步,感覺好像不是很舒適描扯,可以用調(diào)用算數(shù)函數(shù)的方式,為NaN直接填充想要的值趟薄。


靈活的算數(shù)方法
df1.add(df2, fill_value = 0)
輸出:
    b   c   d   e
Colorado    6.0 7.0 8.0 NaN
Ohio    3.0 1.0 6.0 5.0
Oregon  9.0 NaN 10.0    11.0
Texas   9.0 4.0 12.0    8.0
Utah    0.0 NaN 1.0 2.0

我用的例子跟書上的不一樣绽诚,然后發(fā)現(xiàn)fill_value并不是把所有的NaN全都設(shè)置為0,而是將兩個(gè)數(shù)組不重疊的索引或列上的數(shù)值置為0杭煎,然后再完成算數(shù)恩够,但如果某個(gè)索引和列對(duì)應(yīng)的數(shù)據(jù)在兩個(gè)數(shù)組中都沒有,那么其數(shù)值仍然是Na羡铲。

4蜂桶、DataFrame與Series之間的運(yùn)算(廣播)

DataFrame與Series之間的運(yùn)算可以分為兩種情況:
一是匹配列,沿著行廣播犀勒。

frame = DataFrame(np.arange(12).reshape((4, 3)), columns = list('bde'), index = ['Utah', 'Ohio', 'Texas', 'Oregon'])
series = frame.ix['Utah']
frame - series
輸出:
    b   d   e
Utah    0   0   0
Ohio    3   3   3
Texas   6   6   6
Oregon  9   9   9

如果DataFrame的列在Series的索引中找不到屎飘,則以Na填充。

series2 = Series(range(3), index = ['b', 'e', 'f'])
frame + series2
輸出:
    b   d   e   f
Utah    0.0 NaN 3.0 NaN
Ohio    3.0 NaN 6.0 NaN
Texas   6.0 NaN 9.0 NaN
Oregon  9.0 NaN 12.0    NaN

如果希望DataFrame的行匹配到Series的index贾费,并且在列上廣播钦购,則必須使用調(diào)用函數(shù)方法。

series3 = frame['d']
frame.sub(series3, axis = 0)
輸出:
    b   d   e
Utah    -1  0   1
Ohio    -1  0   1
Texas   -1  0   1
Oregon  -1  0   1

axis代表要匹配的軸褂萧,這里要匹配的是DataFrame的行押桃,所以axis = 0。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末导犹,一起剝皮案震驚了整個(gè)濱河市唱凯,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌谎痢,老刑警劉巖磕昼,帶你破解...
    沈念sama閱讀 218,941評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異节猿,居然都是意外死亡票从,警方通過查閱死者的電腦和手機(jī)漫雕,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,397評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來峰鄙,“玉大人浸间,你說我怎么就攤上這事∫髁瘢” “怎么了魁蒜?”我有些...
    開封第一講書人閱讀 165,345評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)吩翻。 經(jīng)常有香客問我兜看,道長(zhǎng),這世上最難降的妖魔是什么仿野? 我笑而不...
    開封第一講書人閱讀 58,851評(píng)論 1 295
  • 正文 為了忘掉前任铣减,我火速辦了婚禮,結(jié)果婚禮上脚作,老公的妹妹穿的比我還像新娘葫哗。我一直安慰自己,他們只是感情好球涛,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,868評(píng)論 6 392
  • 文/花漫 我一把揭開白布劣针。 她就那樣靜靜地躺著,像睡著了一般亿扁。 火紅的嫁衣襯著肌膚如雪捺典。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,688評(píng)論 1 305
  • 那天从祝,我揣著相機(jī)與錄音襟己,去河邊找鬼。 笑死牍陌,一個(gè)胖子當(dāng)著我的面吹牛擎浴,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播毒涧,決...
    沈念sama閱讀 40,414評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼贮预,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼!你這毒婦竟也來了契讲?” 一聲冷哼從身側(cè)響起仿吞,我...
    開封第一講書人閱讀 39,319評(píng)論 0 276
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎捡偏,沒想到半個(gè)月后唤冈,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,775評(píng)論 1 315
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡银伟,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,945評(píng)論 3 336
  • 正文 我和宋清朗相戀三年你虹,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了凉当。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 40,096評(píng)論 1 350
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡售葡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出忠藤,到底是詐尸還是另有隱情挟伙,我是刑警寧澤,帶...
    沈念sama閱讀 35,789評(píng)論 5 346
  • 正文 年R本政府宣布模孩,位于F島的核電站尖阔,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏榨咐。R本人自食惡果不足惜介却,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,437評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望块茁。 院中可真熱鬧齿坷,春花似錦、人聲如沸数焊。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,993評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽佩耳。三九已至遂蛀,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間干厚,已是汗流浹背李滴。 一陣腳步聲響...
    開封第一講書人閱讀 33,107評(píng)論 1 271
  • 我被黑心中介騙來泰國(guó)打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留蛮瞄,地道東北人所坯。 一個(gè)月前我還...
    沈念sama閱讀 48,308評(píng)論 3 372
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像裕坊,于是被迫代替她去往敵國(guó)和親包竹。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,037評(píng)論 2 355

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