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

高效的10個Pandas函數,你都用過了嗎?

開發 后端
andas是python中最主要的數據分析庫之一,它提供了非常多的函數、方法,可以高效地處理并分析數據。這篇文章將會配合實例,講解20個重要的pandas函數。

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

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

介紹這些函數之前,第一步先要導入pandas和numpy。

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

高效的10個Pandas函數,你都用過了嗎?

1. Query

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

用法:

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

參數作用:

  • expr:要評估的查詢字符串;
  • inplace=False:查詢是應該修改數據還是返回修改后的副本
  • kwargs:dict關鍵字參數

首先生成一段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 

高效的10個Pandas函數,你都用過了嗎?

過濾查詢用起來比較簡單,比如要查列value_1<value_2的行記錄:

  1. df.query('value_1 < value_2') 

高效的10個Pandas函數,你都用過了嗎?

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

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

高效的10個Pandas函數,你都用過了嗎?

2. Insert

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

用法:

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

參數作用:

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

接著用前面的df:

高效的10個Pandas函數,你都用過了嗎?

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

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

高效的10個Pandas函數,你都用過了嗎?

3. Cumsum

Cumsum是pandas的累加函數,用來求列的累加值。

用法:

  1. DataFrame.cumsum(axis=Noneskipna=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)進行值的累加。

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

高效的10個Pandas函數,你都用過了嗎?

4. Sample

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

用法:

  1. DataFrame.sample(n=Nonefrac=Nonereplace=Falseweights=Nonerandom_state=Noneaxis=None

參數作用:

(1) n:要抽取的行數

(2) frac:抽取行的比例

  • 例如frac=0.8,就是抽取其中80%

(3) replace:是否為有放回抽樣,

  • True:有放回抽樣
  • False:未放回抽樣

(4) weights:字符索引或概率數組

(5) random_state :隨機數發生器種子

(6) axis:選擇抽取數據的行還是列

  • axis=0:抽取行
  • axis=1:抽取列

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

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

高效的10個Pandas函數,你都用過了嗎?

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

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

高效的10個Pandas函數,你都用過了嗎?

5. Where

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

用法:

  1. DataFrame.where(cond, other=naninplace=Falseaxis=Nonelevel=Noneerrors='raise'try_cast=Falseraise_on_error=None

參數作用:

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

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

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

高效的10個Pandas函數,你都用過了嗎?

Where是一種掩碼操作。

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

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)] 

高效的10個Pandas函數,你都用過了嗎?

7. Loc and iloc

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

用法:

  1. years = ['2010','2014','2017'] 
  2. df[df.year.isin(years)] 
  • loc:按標簽(column和index)選擇行和列
  • iloc:按索引位置選擇行和列

選擇df第1~3行、第1~2列的數據,使用iloc:

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

高效的10個Pandas函數,你都用過了嗎?

使用loc:

  1. df.loc[:2,['group','year']]1 
高效的10個Pandas函數,你都用過了嗎?

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

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

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

高效的10個Pandas函數,你都用過了嗎?

8. Pct_change

Pct_change是一個統計函數,用于表示當前元素與前面元素的相差百分比,兩元素的區間可以調整。

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

用法:

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

參數作用:

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

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

  1. df.value_1.pct_change() 

高效的10個Pandas函數,你都用過了嗎?

9. Rank

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

比如有一個序列[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

參數作用:

(1) axis:行或者列

(2) 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: 相同值會按照其在序列中的相對位置定值

(3) ascending:正序和倒序

對df中列value_1進行排名:

  1. df['rank_1'] = df['value_1'].rank() 
  2. df 
高效的10個Pandas函數,你都用過了嗎?

10. Melt

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

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

高效的10個Pandas函數,你都用過了嗎?

用法:

  1. pandas.melt(frame, id_vars=Nonevalue_vars=Nonevar_name=Nonevalue_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, 它將使用此級別來融化

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

  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 
高效的10個Pandas函數,你都用過了嗎?

現在將day1、day2列變成變量列,再加一個值列:

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

高效的10個Pandas函數,你都用過了嗎?

 

責任編輯:趙寧寧 來源: 今日頭條
相關推薦

2020-08-16 10:58:20

Pandaspython開發

2023-12-22 16:39:47

Java函數式接口開發

2010-11-26 09:45:56

2021-02-22 09:10:10

數字人民幣DCEP區塊鏈

2022-05-27 09:02:31

Openbase開源前端

2020-12-02 14:50:50

Windows 10Windows微軟

2010-07-09 09:01:55

2022-06-01 06:12:29

Windows應用

2023-10-10 08:33:40

編程范式命令式編程

2022-02-04 23:34:22

Windows 10技巧微軟

2020-11-30 05:51:52

Windows10

2023-11-22 07:42:01

2018-06-06 09:10:34

編程語言Python庫

2023-01-28 10:27:04

2009-07-20 10:18:49

PHP 5.3命名空間

2011-07-06 09:27:55

Linux命令

2019-01-10 16:52:26

華為

2017-11-01 10:31:08

Docker

2020-12-25 17:19:27

工具網絡網站

2023-10-12 15:02:21

PythonPandas數據分析
點贊
收藏

51CTO技術棧公眾號

日本欧美亚洲| 国产免费黄色小视频| 在线播放毛片| 久久久精品蜜桃| 亚洲a一级视频| 97久久精品一区二区三区的观看方式| 精品久久久久久久久久| 黄色一级视频片| 老司机精品福利视频| 欧美又大粗又爽又黄大片视频| 国产精品186在线观看在线播放| 亚洲一区二区免费视频| 丰满人妻中伦妇伦精品app| 亚洲一区视频| 成人春色激情网| 欧一区二区三区| 亚洲图片欧美午夜| 色图在线观看| 国产一区二区久久| 国产精国产精品| 天堂网在线免费观看| 3d动漫一区二区三区在线观看| 国产不卡av一区二区| 国产欧美69| 91九色最新地址| 水蜜桃一区二区| 美女欧美视频在线观看免费 | 不卡一区中文字幕| 成人欧美一区二区三区视频xxx | 久久久久久99精品| 中文字幕久精品免| 日本系列欧美系列| 欧美日本韩国在线| 亚洲一级网站| 亚洲一区二区三区久久| av网站免费在线| 99久久99久久| 亚洲国产一区二区三区在线播放| 97不卡在线视频| 日本免费一区二区三区视频| 日韩一区二区三区国产| 欧美伊人亚洲伊人色综合动图| 日韩高清有码在线| 亚洲国产成人二区| 亚洲图片在区色| 国产成人午夜性a一级毛片| 在线观看精品自拍私拍| jizz免费一区二区三区| 中日韩美女免费视频网站在线观看 | 另类天堂av| 蜜桃欧美视频| 久久久久.com| 黄瓜视频免费观看在线观看www| 日韩国产欧美在线观看| 一区二区在线中文字幕电影视频| 久久99精品久久久久久久久久久久 | 国产精品天天狠天天看| 亚洲国产精品嫩草影院久久av| 高清欧美性猛交xxxx| 久久porn| 成人性教育视频在线观看| 欧美ab在线视频| 欧美不卡1区2区3区| 日韩国产欧美在线播放| 在线观看三级网站| 久久一夜天堂av一区二区三区| 国产高潮免费视频| 亚洲成人一区二区在线观看| 国产私拍精品| 日韩福利视频在线观看| 国产高清视频一区二区| 欧美日韩不卡合集视频| 日韩精选在线| 不卡一卡2卡3卡4卡精品在| 亚洲欧美久久久| 131美女爱做视频| 亚洲成av人影院| 在线免费观看的av| 欧美成人精品一区| 牛牛国产精品| 免费特级黄色片| 亚洲精品国产一区二区三区四区在线| 色视频www在线播放| 制服丝袜亚洲播放| 亚洲开心激情网| 国产免费av国片精品草莓男男| 中文字幕欧美国内| 国产香蕉久久| 亚洲视频一区二区| 欧美成熟毛茸茸| 欧美日韩免费观看一区二区三区| 国产玉足脚交久久欧美| 先锋影音资源999| 亚洲永久免费| 久久久久久久9| 亚洲一区二区三区小说| 欧美14一18处毛片| 欧美亚洲在线播放| 日韩电影在线观看电影| 久久精品国语| 久久网站免费视频| 91福利国产精品| 91麻豆精品| 国产日韩欧美一区二区| 久久综合av免费| 黄色动漫在线| 青青草一区二区| 国产乱码精品一区二区三 | 欧美精品一二三四| 日韩精品一区二区三区免费视频| 亚洲一区二区久久久久久| 国产精品原创巨作av| 欧洲视频在线免费观看| 精品国产依人香蕉在线精品| 99热免费精品| 国产夫妻视频| 久久精品99久久香蕉国产色戒| 韩日视频一区| 成人高清在线观看免费| 精品视频在线导航| 国内揄拍国内精品久久| 羞羞小视频在线观看| 亚洲欧美中文另类| 亚洲一区日韩| 国产一区二区影视| 国产精品96久久久久久又黄又硬| 成人免费av在线| 黑人精品视频| 看高清中日韩色视频| 香蕉成人伊视频在线观看| 日韩大片一区二区| 川上优av一区二区线观看| 91丨porny丨国产| 国产直播在线| 国产精品普通话对白| 97公开免费视频| 国产网站欧美日韩免费精品在线观看| 精品av久久久久电影| 在线观看国产高清视频| 欧美亚洲第一页| 国产女主播在线一区二区| 91伊人久久| 波多野结衣 作品| 国产乱子伦三级在线播放| 久久人人爽人人爽人人av| 日本亚洲欧美三级| 日韩专区中文字幕| 精品久久一区二区| 婷婷开心激情综合| 精品九九久久| 亚洲高潮无码久久| 日韩精品一二三四区| 日韩精品乱码免费| 男人添女人下部高潮视频在线观看| 2022国产精品| 欧美综合在线视频| 夜夜嗨网站十八久久| 免费在线视频你懂得| 亚洲一区二区三区乱码aⅴ蜜桃女| 午夜精品久久久久久久蜜桃app| 国产99久久| 动漫黄在线观看| 成人精品一区二区三区| 五月综合激情日本mⅴ| 亚洲午夜精品一区二区国产| 国产小视频福利在线| 精品麻豆av| 精品国产伦一区二区三区免费| 美国毛片一区二区三区| 国产传媒av在线| 欧美 日韩 国产在线观看| 另类少妇人与禽zozz0性伦| 国产亚洲自拍一区| 免费看av成人| 99中文字幕一区| 综合操久久久| 久久中文字幕视频| 亚洲一区二区视频| 一区二区三区四区五区精品视频 | 99国产精品视频免费观看| 亚洲精品国产嫩草在线观看| 男人添女荫道口图片| 欧美激情久久久久| 久久综合色鬼综合色| 亚洲另类中文字| 亚洲男同1069视频| 亚洲精品国产品国语在线| 色综合老司机第九色激情| 欧美久久久久久久久久| 国产日韩欧美精品一区| 国产精品免费不| 区一区二日本| 在线视频福利一区| 色www精品视频在线观看| 91国内免费在线视频| 一区二区三区蜜桃网| 亚洲激情在线| av一区在线| 亚洲精品视频区| 国产高清免费在线|