【Python基础】高效的10个Pandas函数,你都用过吗?
文章來源于Python大數據分析,作者朱衛軍
文章來源:towardsdatascience
作者:Soner Y?ld?r?m
翻譯\編輯:Python大數據分析
Pandas是python中最主要的數據分析庫之一,它提供了非常多的函數、方法,可以高效地處理并分析數據。讓pandas如此受歡迎的原因是它簡潔、靈活、功能強大的語法。
這篇文章將會配合實例,講解10個重要的pandas函數。其中有一些很常用,相信你可能用到過。還有一些函數出現的頻率沒那么高,但它們同樣是分析數據的得力幫手。
介紹這些函數之前,第一步先要導入pandas和numpy。
import?numpy?as?np import?pandas?as?pd1. Query
Query是pandas的過濾查詢函數,使用布爾表達式來查詢DataFrame的列,就是說按照列的規則進行過濾操作。
用法:
pandas.DataFrame.query(self,?expr,?inplace?=?False,?**kwargs)參數作用:
expr:要評估的查詢字符串;
inplace=False:查詢是應該修改數據還是返回修改后的副本
kwargs:dict關鍵字參數
首先生成一段df:
values_1?=?np.random.randint(10,?size=10) values_2?=?np.random.randint(10,?size=10) years?=?np.arange(2010,2020) groups?=?['A','A','B','A','B','B','C','A','C','C'] df?=?pd.DataFrame({'group':groups,?'year':years,?'value_1':values_1,?'value_2':values_2}) df過濾查詢用起來比較簡單,比如要查列value_1<value_2的行記錄:
df.query('value_1?<?value_2')查詢列year>=2016的行記錄:
df.query('year?>=?2016?')2. Insert
Insert用于在DataFrame的指定位置中插入新的數據列。默認情況下新列是添加到末尾的,但可以更改位置參數,將新列添加到任何位置。
用法:
Dataframe.insert(loc,?column,?value,?allow_duplicates=False)參數作用:
loc: ?int型,表示插入位置在第幾列;若在第一列插入數據,則 loc=0
column: 給插入的列取名,如 column='新的一列'
value:新列的值,數字、array、series等都可以
allow_duplicates: 是否允許列名重復,選擇Ture表示允許新的列名與已存在的列名重復
接著用前面的df:
在第三列的位置插入新列:
#新列的值 new_col?=?np.random.randn(10) #在第三列位置插入新列,從0開始計算 df.insert(2,?'new_col',?new_col) df3. Cumsum
Cumsum是pandas的累加函數,用來求列的累加值。用法:
DataFrame.cumsum(axis=None,?skipna=True,?args,?kwargs)參數作用:
axis:index或者軸的名字
skipna:排除NA/null值
以前面的df為例,group列有A、B、C三組,year列有多個年份。我們只知道當年度的值value_1、value_2,現在求group分組下的累計值,比如A、2014之前的累計值,可以用cumsum函數來實現。
當然僅用cumsum函數沒辦法對groups (A, B, C)進行區分,所以需要結合分組函數groupby分別對(A, B, C)進行值的累加。
df['cumsum_2']?=?df[['value_2','group']].groupby('group').cumsum() df4. Sample
Sample用于從DataFrame中隨機選取若干個行或列。用法:
DataFrame.sample(n=None,?frac=None,?replace=False,?weights=None,?random_state=None,?axis=None)參數作用:
n:要抽取的行數
frac:抽取行的比例 例如frac=0.8,就是抽取其中80%
replace:是否為有放回抽樣, True:有放回抽樣 False:未放回抽樣
weights:字符索引或概率數組
random_state :隨機數發生器種子
axis:選擇抽取數據的行還是列 axis=0:抽取行 axis=1:抽取列
比如要從df中隨機抽取5行:
sample1?=?df.sample(n=5) sample1從df隨機抽取60%的行,并且設置隨機數種子,每次能抽取到一樣的樣本:
sample2?=?df.sample(frac=0.6,random_state=2) sample25. Where
Where用來根據條件替換行或列中的值。如果滿足條件,保持原來的值,不滿足條件則替換為其他值。默認替換為NaN,也可以指定特殊值。
用法:
DataFrame.where(cond,?other=nan,?inplace=False,?axis=None,?level=None,?errors='raise',?try_cast=False,?raise_on_error=None)參數作用:
cond:布爾條件,如果 cond 為真,保持原來的值,否則替換為other
other:替換的特殊值
inplace:inplace為真則在原數據上操作,為False則在原數據的copy上操作
axis:行或列
將df中列value_1里小于5的值替換為0:
df['value_1'].where(df['value_1']?>?5?,?0)Where是一種掩碼操作。
「掩碼」(英語:Mask)在計算機學科及數字邏輯中指的是一串二進制數字,通過與目標數字的按位操作,達到屏蔽指定位而實現需求。
6. Isin
Isin也是一種過濾方法,用于查看某列中是否包含某個字符串,返回值為布爾Series,來表明每一行的情況。
用法:
Series.isin(values) 或者 DataFrame.isin(values)篩選df中year列值在['2010','2014','2017']里的行:
years?=?['2010','2014','2017'] df[df.year.isin(years)]7. Loc and iloc
Loc和iloc通常被用來選擇行和列,它們的功能相似,但用法是有區別的。
用法:
DataFrame.loc[] 或者 DataFrame.iloc[]loc:按標簽(column和index)選擇行和列
iloc:按索引位置選擇行和列
選擇df第1~3行、第1~2列的數據,使用iloc:
df.iloc[:3,:2]使用loc:
df.loc[:2,['group','year']]1提示:使用loc時,索引是指index值,包括上邊界。iloc索引是指行的位置,不包括上邊界。
選擇第1、3、5行,year和value_1列:
df.loc[[1,3,5],['year','value_1']]8. Pct_change
Pct_change是一個統計函數,用于表示當前元素與前面元素的相差百分比,兩元素的區間可以調整。
比如說給定三個元素[2,3,6],計算相差百分比后得到[NaN, 0.5, 1.0],從第一個元素到第二個元素增加50%,從第二個元素到第三個元素增加100%。
用法:
DataFrame.pct_change(periods=1,?fill_method=‘pad’,?limit=None,?freq=None,?**kwargs)參數作用:
periods:間隔區間,即步長
fill_method:處理空值的方法
對df的value_1列進行增長率的計算:
df.value_1.pct_change()9. Rank
Rank是一個排名函數,按照規則(從大到小,從小到大)給原序列的值進行排名,返回的是排名后的名次。
比如有一個序列[1,7,5,3],使用rank從小到大排名后,返回[1,4,3,2],這就是前面那個序列每個值的排名位置。
用法:
rank(axis=0,?method:?str?=?'average',?numeric_only:?Union[bool,?NoneType]?=?None,?na_option:?str?=?'keep',?ascending:?bool?=?True,?pct:?bool?=?False)參數作用:
axis:行或者列
method:返回名次的方式,可選{‘average’, ‘min’, ‘max’, ‘first’, ‘dense’}
method=average 默認設置: 相同的值占據前兩名,分不出誰是1誰是2,那么去中值即1.5,下面一名為第三名
method=max: 兩人并列第 2 名,下一個人是第 3 名
method=min: 兩人并列第 1 名,下一個人是第 3 名
method=dense: 兩人并列第1名,下一個人是第 2 名
method=first: 相同值會按照其在序列中的相對位置定值ascending:正序和倒序
對df中列value_1進行排名:
df['rank_1']?=?df['value_1'].rank() df10. Melt
Melt用于將寬表變成窄表,是 pivot透視逆轉操作函數,將列名轉換為列數據(columns name → column values),重構DataFrame。
簡單說就是將指定的列放到鋪開放到行上變成兩列,類別是variable(可指定)列,值是value(可指定)列。
用法:
pandas.melt(frame,?id_vars=None,?value_vars=None,?var_name=None,?value_name='value',?col_level=None)參數作用:
frame:它是指DataFrame
id_vars [元組, 列表或ndarray, 可選]:不需要被轉換的列名,引用用作標識符變量的列
value_vars [元組, 列表或ndarray, 可選]:引用要取消透視的列。如果未指定, 請使用未設置為id_vars的所有列
var_name [scalar]:指代用于”變量”列的名稱。如果為None, 則使用- - frame.columns.name或’variable’
value_name [標量, 默認為’value’]:是指用于” value”列的名稱
col_level [int或string, 可選]:如果列為MultiIndex, 它將使用此級別來融化
例如有一串數據,表示不同城市和每天的人口流動:
import?pandas?as?pd df1?=?pd.DataFrame({'city':?{0:?'a',?1:?'b',?2:?'c'},'day1':?{0:?1,?1:?3,?2:?5},'day2':?{0:?2,?1:?4,?2:?6}}) df1現在將day1、day2列變成變量列,再加一個值列:
pd.melt(df1,?id_vars=['city']) 往期精彩回顧適合初學者入門人工智能的路線及資料下載機器學習及深度學習筆記等資料打印機器學習在線手冊深度學習筆記專輯《統計學習方法》的代碼復現專輯 AI基礎下載機器學習的數學基礎專輯獲取一折本站知識星球優惠券,復制鏈接直接打開:https://t.zsxq.com/662nyZF本站qq群1003271085。加入微信群請掃碼進群(如果是博士或者準備讀博士請說明):總結
以上是生活随笔為你收集整理的【Python基础】高效的10个Pandas函数,你都用过吗?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 【经验】刚读硕士怎么感觉学机器学习和深度
- 下一篇: 【经验】对“面试造火箭,入职拧螺钉”的看