国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

高效的10個Pandas函數(shù),你都用過嗎?

開發(fā) 前端
Pandas是python中比較主要的數(shù)據(jù)分析庫之一,它提供了非常多的函數(shù)、方法,可以高效地處理并分析數(shù)據(jù)。讓pandas如此受歡迎的原因是它簡潔、靈活、功能強大的語法。

 Pandas是python中比較主要的數(shù)據(jù)分析庫之一,它提供了非常多的函數(shù)、方法,可以高效地處理并分析數(shù)據(jù)。讓pandas如此受歡迎的原因是它簡潔、靈活、功能強大的語法。

[[337927]]

這篇文章將會配合實例,講解10個重要的pandas函數(shù)。其中有一些很常用,相信你可能用到過。還有一些函數(shù)出現(xiàn)的頻率沒那么高,但它們同樣是分析數(shù)據(jù)的得力幫手。

介紹這些函數(shù)之前,第一步先要導(dǎo)入pandas和numpy。

 

  1. import numpy as np 
  2. import pandas as pd 

1. Query

Query是pandas的過濾查詢函數(shù),使用布爾表達式來查詢DataFrame的列,就是說按照列的規(guī)則進行過濾操作。

用法:

 

  1. pandas.DataFrame.query(self, expr, inplace = False, **kwargs) 

參數(shù)作用:

  • expr:要評估的查詢字符串;
  • inplace=False:查詢是應(yīng)該修改數(shù)據(jù)還是返回修改后的副本
  • kwargs:dict關(guān)鍵字參數(shù)

首先生成一段df:

 

  1. values_1 = np.random.randint(10, size=10) 
  2. values_2 = np.random.randint(10, size=10) 
  3. years = np.arange(2010,2020) 
  4. groups = ['A','A','B','A','B','B','C','A','C','C'
  5. df = pd.DataFrame({'group':groups, 'year':years, 'value_1':values_1, 'value_2':values_2}) 
  6. df 

 

過濾查詢用起來比較簡單,比如要查列value_1

 

  1. df.query('value_1 < value_2'

 

 

 

查詢列year>=2016的行記錄:

 

  1. df.query('year >= 2016 '

 

 

 

2. Insert

Insert用于在DataFrame的指定位置中插入新的數(shù)據(jù)列。默認情況下新列是添加到末尾的,但可以更改位置參數(shù),將新列添加到任何位置。

用法:

  1. Dataframe.insert(loc, column, value, allow_duplicates=False

參數(shù)作用:

  • loc: int型,表示插入位置在第幾列;若在第一列插入數(shù)據(jù),則 loc=0
  • column: 給插入的列取名,如 column='新的一列'
  • value:新列的值,數(shù)字、array、series等都可以
  • allow_duplicates: 是否允許列名重復(fù),選擇Ture表示允許新的列名與已存在的列名重復(fù)

接著用前面的df:

 

 

 

在第三列的位置插入新列:

 

  1. #新列的值 
  2. new_col = np.random.randn(10) 
  3. #在第三列位置插入新列,從0開始計算 
  4. df.insert(2, 'new_col', new_col) 
  5. df 

 

 

 

3. Cumsum

Cumsum是pandas的累加函數(shù),用來求列的累加值。用法:

 

  1. DataFrame.cumsum(axis=None, skipna=True, args, kwargs) 

參數(shù)作用:

  • axis:index或者軸的名字
  • skipna:排除NA/null值

以前面的df為例,group列有A、B、C三組,year列有多個年份。我們只知道當年度的值value_1、value_2,現(xiàn)在求group分組下的累計值,比如A、2014之前的累計值,可以用cumsum函數(shù)來實現(xiàn)。

當然僅用cumsum函數(shù)沒辦法對groups (A, B, C)進行區(qū)分,所以需要結(jié)合分組函數(shù)groupby分別對(A, B, C)進行值的累加。

 

  1. df['cumsum_2'] = df[['value_2','group']].groupby('group').cumsum() 
  2. df 

 

 

 

4. Sample

Sample用于從DataFrame中隨機選取若干個行或列。用法:

 

  1. DataFrame.sample(n=None, frac=None, replace=False, weights=None, random_state=None, axis=None) 

參數(shù)作用:

  • n:要抽取的行數(shù)
  • frac:抽取行的比例 例如frac=0.8,就是抽取其中80%
  • replace:是否為有放回抽樣, True:有放回抽樣 False:未放回抽樣
  • weights:字符索引或概率數(shù)組
  • random_state :隨機數(shù)發(fā)生器種子
  • axis:選擇抽取數(shù)據(jù)的行還是列 axis=0:抽取行 axis=1:抽取列

比如要從df中隨機抽取5行:

 

  1. sample1 = df.sample(n=5) 
  2. sample1 

 

 

 

從df隨機抽取60%的行,并且設(shè)置隨機數(shù)種子,每次能抽取到一樣的樣本:

 

  1. sample2 = df.sample(frac=0.6,random_state=2) 
  2. sample2 

 

 

 

5. Where

Where用來根據(jù)條件替換行或列中的值。如果滿足條件,保持原來的值,不滿足條件則替換為其他值。默認替換為NaN,也可以指定特殊值。

用法:

 

  1. DataFrame.where(cond, other=nan, inplace=False, axis=None, level=None, errors='raise', try_cast=False, raise_on_error=None) 

參數(shù)作用:

  • cond:布爾條件,如果 cond 為真,保持原來的值,否則替換為other
  • other:替換的特殊值
  • inplace:inplace為真則在原數(shù)據(jù)上操作,為False則在原數(shù)據(jù)的copy上操作
  • axis:行或列

將df中列value_1里小于5的值替換為0:

 

  1. df['value_1'].where(df['value_1'] > 5 , 0) 

 

 

 

Where是一種掩碼操作。

「掩碼」(英語:Mask)在計算機學(xué)科及數(shù)字邏輯中指的是一串二進制數(shù)字,通過與目標數(shù)字的按位操作,達到屏蔽指定位而實現(xiàn)需求。

6. Isin

Isin也是一種過濾方法,用于查看某列中是否包含某個字符串,返回值為布爾Series,來表明每一行的情況。

用法:

 

  1. Series.isin(values
  2. 或者 
  3. DataFrame.isin(values

篩選df中year列值在['2010','2014','2017']里的行:

 

  1. years = ['2010','2014','2017'
  2. df[df.year.isin(years)] 

 

 

 

7. Loc and iloc

Loc和iloc通常被用來選擇行和列,它們的功能相似,但用法是有區(qū)別的。

用法:

 

  1. DataFrame.loc[] 
  2. 或者 
  3. DataFrame.iloc[] 
  • loc:按標簽(column和index)選擇行和列
  • iloc:按索引位置選擇行和列

選擇df第1~3行、第1~2列的數(shù)據(jù),使用iloc:

 

  1. df.iloc[:3,:2] 

 

 

 

 

使用loc:

 

  1. df.loc[:2,['group','year']]1 

 

 

 

提示:使用loc時,索引是指index值,包括上邊界。iloc索引是指行的位置,不包括上邊界。

選擇第1、3、5行,year和value_1列:

 

  1. df.loc[[1,3,5],['year','value_1']] 

 

8. Pct_change

Pct_change是一個統(tǒng)計函數(shù),用于表示當前元素與前面元素的相差百分比,兩元素的區(qū)間可以調(diào)整。

比如說給定三個元素[2,3,6],計算相差百分比后得到[NaN, 0.5, 1.0],從第一個元素到第二個元素增加50%,從第二個元素到第三個元素增加100%。

用法:

 

  1. DataFrame.pct_change(periods=1, fill_method=‘pad’, limit=None, freq=None, **kwargs) 

參數(shù)作用:

  • periods:間隔區(qū)間,即步長
  • fill_method:處理空值的方法

對df的value_1列進行增長率的計算:

 

  1. df.value_1.pct_change() 

 

 

 

9. Rank

Rank是一個排名函數(shù),按照規(guī)則(從大到小,從小到大)給原序列的值進行排名,返回的是排名后的名次。

比如有一個序列[1,7,5,3],使用rank從小到大排名后,返回[1,4,3,2],這就是前面那個序列每個值的排名位置。

用法:

 

  1. rank(axis=0, method: str = 'average', numeric_only: Union[bool, NoneType] = None, na_option: str = 'keep', ascending: bool = True, pct: bool = False

參數(shù)作用:

  • axis:行或者列
  • method:返回名次的方式,可選{‘average’, ‘min’, ‘max’, ‘first’, ‘dense’}

method=average 默認設(shè)置: 相同的值占據(jù)前兩名,分不出誰是1誰是2,那么去中值即1.5,下面一名為第三名

method=max: 兩人并列第 2 名,下一個人是第 3 名

method=min: 兩人并列第 1 名,下一個人是第 3 名

method=dense: 兩人并列第1名,下一個人是第 2 名

method=first: 相同值會按照其在序列中的相對位置定值

  • ascending:正序和倒序

對df中列value_1進行排名:

 

  1. df['rank_1'] = df['value_1'].rank() 
  2. df 

 

 

 

10. Melt

Melt用于將寬表變成窄表,是 pivot透視逆轉(zhuǎn)操作函數(shù),將列名轉(zhuǎn)換為列數(shù)據(jù)(columns name → column values),重構(gòu)DataFrame。

簡單說就是將指定的列放到鋪開放到行上變成兩列,類別是variable(可指定)列,值是value(可指定)列。

 

 

 

 

用法:

 

  1. pandas.melt(frame, id_vars=None, value_vars=None, var_name=None, value_name='value', col_level=None) 

參數(shù)作用:

  • frame:它是指DataFrame
  • id_vars [元組, 列表或ndarray, 可選]:不需要被轉(zhuǎn)換的列名,引用用作標識符變量的列
  • value_vars [元組, 列表或ndarray, 可選]:引用要取消透視的列。如果未指定, 請使用未設(shè)置為id_vars的所有列
  • var_name [scalar]:指代用于”變量”列的名稱。如果為None, 則使用- - frame.columns.name或’variable’
  • value_name [標量, 默認為’value’]:是指用于” value”列的名稱
  • col_level [int或string, 可選]:如果列為MultiIndex, 它將使用此級別來融化

例如有一串數(shù)據(jù),表示不同城市和每天的人口流動:

 

  1. import pandas as pd 
  2. df1 = pd.DataFrame({'city': {0: 'a', 1: 'b', 2: 'c'}, 
  3.                      'day1': {0: 1, 1: 3, 2: 5}, 
  4.                      'day2': {0: 2, 1: 4, 2: 6}}) 
  5. df1 

 

現(xiàn)在將day1、day2列變成變量列,再加一個值列:

 

  1. pd.melt(df1, id_vars=['city']) 

 

 

 

責(zé)任編輯:華軒 來源: Python大數(shù)據(jù)分析
相關(guān)推薦

2020-08-23 09:18:30

Pandas函數(shù)數(shù)據(jù)分析

2023-12-22 16:39:47

Java函數(shù)式接口開發(fā)

2023-11-22 07:42:01

2022-02-04 23:34:22

Windows 10技巧微軟

2023-01-28 10:27:04

2020-12-02 14:50:50

Windows 10Windows微軟

2024-11-08 09:37:10

C#組件

2020-10-13 14:54:11

機器學(xué)習(xí)技術(shù)工具

2022-06-01 06:12:29

Windows應(yīng)用

2021-03-20 07:20:49

Windows10操作系統(tǒng)微軟

2022-11-05 08:14:25

開發(fā)工具瀏覽器

2020-06-03 16:50:09

Node.js框架開發(fā)

2024-11-07 12:33:47

2020-11-30 05:51:52

Windows10

2018-06-06 09:10:34

編程語言Python庫

2011-07-06 09:27:55

Linux命令

2021-06-04 10:38:33

PythonIDE代碼編輯器

2020-05-27 14:41:51

主流軟件測試工具

2021-11-30 08:44:29

SpringRouter Func函數(shù)式接口

2024-02-27 09:25:51

規(guī)則引擎物聯(lián)網(wǎng)平臺開源
點贊
收藏

51CTO技術(shù)棧公眾號

亚洲欧美在线观看| 久久精品亚洲麻豆av一区二区| 精品一区二区亚洲| 狠狠热免费视频| 99热免费精品| 日韩美女视频中文字幕| 蜜桃av在线| 中文av字幕一区| 91激情在线| 国产精品资源在线看| 中文综合在线观看| 小小水蜜桃在线观看| 国产成人免费视频网站 | 最猛黑人系列在线播放| 亚洲色图国产精品| 88国产精品视频一区二区三区| 亚洲一区二区三区中文字幕| 日韩av卡一卡二| sdde在线播放一区二区| 国产视频一区二区在线| 色在人av网站天堂精品| 欧美久久久久久一卡四| 5月婷婷6月丁香| jizzjizzjizz亚洲女| 99精品全国免费观看视频软件| 国产精品色在线| 国产精品视频久久久| 日本成a人片在线观看| 香港成人在线视频| 可以在线观看的av| 欧洲av一区二区嗯嗯嗯啊| 日韩欧美不卡在线观看视频| 日韩精品中文字幕有码专区| 国产av第一区| 成人性生活视频| 男男视频亚洲欧美| 精品欧美久久久| 黄页视频在线免费观看| 日本视频在线一区| 欧美曰成人黄网| 欧美www在线| 中文字幕97| 不卡一区综合视频| 99亚洲伊人久久精品影院红桃| 中文一区在线播放| 在线不卡中文字幕播放| 国产成人精品久久二区二区91| 国模大尺度私拍在线视频| 欧美精品乱码| 精品国产乱码久久久久久天美| 欧美r级电影在线观看| 国产精品美女久久久久av超清| 男男激情在线| 日韩免费看网站| 狠狠一区二区三区| 无码人妻丰满熟妇区毛片| 欧美狂野另类xxxxoooo| 日韩精品四区| 日本女优北野望在线电影| 欧美国产日本在线| 久久精品亚洲精品国产欧美| 国产精品99| 久久精品一区二| 亚洲欧美制服丝袜| 天堂在线亚洲视频| jizzjizzjizz亚洲女| 亚洲一区电影777| 麻豆mv在线看| 热久久免费视频精品| 国产精品一区在线观看你懂的| 中文在线网在线中文| 欧美www在线| 国产在线精品不卡| av午夜在线| 国产精品网红直播| 亚洲综合成人在线| 亚洲精品一线| 久久久久久久久91| 精品国产亚洲一区二区三区在线| 在线播放一区二区三区| 免费看黄视频网站| 成人网男人的天堂| 永久免费看av| 久久日韩粉嫩一区二区三区| 亚洲欧美国内爽妇网| 新片速递亚洲合集欧美合集| 久久久久免费网| 国产精品亚洲产品| 91九色偷拍| 国产一区欧美| 国产亚洲欧美另类一区二区三区| 奇米亚洲午夜久久精品| 午夜网站在线观看| 精品久久久久久久久久久久久久久久久| 久久国产精品区| 国产在线观看高清视频| 欧美成人乱码一区二区三区| 国产精品无码久久久久| 久久久伊人日本| 中文字幕日本一区| 国产91精品久久久| 夜夜嗨av一区二区三区中文字幕 | 亚洲第一久久影院| eeuss影院95999部| 欧美国产综合色视频| 久久国产情侣| 欧美日韩中文字幕精品| 奇米影视一区二区三区| 亚洲伦理网站| 青青青草网站免费视频在线观看| 狠狠色综合网站久久久久久久| 亚洲精品一线二线三线| 日韩电影第一页| 成人av在线播放网站| 国产一区激情| 国产精品17p| 久草在线资源站资源站| 日本一区高清| 天堂一区在线观看| 在线国产伦理一区| 日本一区视频在线观看| 国产精品aaaa| 国内精品久久久久久中文字幕| 色吧影院999| 欧美午夜电影在线播放| 国产亚洲欧美色| 日本欧美一区二区| av成人在线看| 原千岁中文字幕| 91精品国产吴梦梦| 欧美怡红院视频一区二区三区| 91精品国产色综合久久ai换脸 | 91在线视频免费91| 国产综合色区在线观看| 国产又粗又猛又爽又黄的网站| 久久久久久久久久久91| 一区二区三区免费| 国产91丝袜在线播放0| 琪琪一区二区三区| 久久激情电影| 日韩欧美中文字幕在线视频| 一级毛片在线| 国产亚洲精品自在久久| 精品欧美一区二区在线观看| 亚洲国产99| 777.av| 国产成人高潮免费观看精品| 成人动漫在线一区| 美女视频亚洲色图| 青青在线视频免费| 国产美女直播视频一区| 嫩草影院国产精品| 日韩欧美中文字幕制服| 日本成人在线不卡视频| 国产精品美女久久久| 精品一区二区三区在线观看| 国产精品毛片| 久久激情五月婷婷| 成人激情校园春色| 国产日韩精品视频一区| 国产精品素人一区二区| 欧美色视频日本版| 无吗不卡中文字幕| 亚洲国产第一| www视频在线观看免费| 色综合视频二区偷拍在线 | 日本不卡二区| 国产网友自拍电影在线 | baoyu777.永久免费视频| 亚洲97在线观看| 国产精品午夜免费| 精品中文字幕一区二区三区av| 四虎久久免费| 777av视频| av激情久久| 国产激情视频一区| 在线免费观看日本一区| 毛片不卡一区二区| 美女精品一区最新中文字幕一区二区三区| 亚洲一区在线日韩在线深爱| 久久久神马电影| 色噜噜国产精品视频一区二区| 亚洲第一福利视频| 欧美亚洲国产另类| 青青草国产精品| 97avcom| 日韩一区二区三区观看| 国产成人h网站| 婷婷亚洲五月色综合| 成人国产综合| 亚洲精品在线观看91| 亚洲精品videosex极品| 亚洲电影免费观看| 在线成人高清不卡| 国产91成人在在线播放| 91夜夜揉人人捏人人添红杏| 精品综合在线| 中文字幕av不卡在线| av资源种子在线观看| 四虎黄色影院|