自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

11個Python Pandas小技巧讓你的工作更高效(附代碼實例)

開發(fā) 后端
本文為你介紹Pandas隱藏的炫酷小技巧,我相信這些會對你有所幫助?;蛟S本文中的某些命令你早已知曉,只是沒意識到它還有這種打開方式。

本文為你介紹Pandas隱藏的炫酷小技巧,我相信這些會對你有所幫助。

或許本文中的某些命令你早已知曉,只是沒意識到它還有這種打開方式。

 

Pandas是一個在Python中廣泛應用的數(shù)據(jù)分析包。市面上有很多關(guān)于Pandas的經(jīng)典教程,但本文介紹幾個隱藏的炫酷小技巧,我相信這些會對你有所幫助。

1. read_csv

這是讀取數(shù)據(jù)的入門級命令。當要你所讀取的數(shù)據(jù)量特別大時,試著加上這個參數(shù)nrows = 5,就可以在載入全部數(shù)據(jù)前先讀取一小部分數(shù)據(jù)。如此一來,就可以避免選錯分隔符這樣的錯誤啦(數(shù)據(jù)不一定都是用逗號來分隔)。

(或者在linux系統(tǒng)中,你可以使用‘head’來展示任意文本文件的前五行:head -c 5 data.txt)

接下來,用 df.columns.tolist() 可以提取每一列并轉(zhuǎn)換成list。還可以加上usecols = [‘c1’, ‘c2’, … ]來載入所需要的指定列。另外,如果你知道某些列的類型,你可以加上dtype = {‘c1’: str, ‘c2’: int, …} ,這樣會加快載入的速度。加入這些參數(shù)的另一大好處是,如果這一列中同時含有字符串和數(shù)值類型,而你提前聲明把這一列看作是字符串,那么這一列作為主鍵來融合多個表時,就不會報錯了。

2. select_dtypes

如果已經(jīng)在Python中完成了數(shù)據(jù)的預處理,這個命令可以幫你節(jié)省一定的時間。在讀取了表格之后,每一列的默認數(shù)據(jù)類型將會是bool,int64,float64,object,category,timedelta64,或者datetime64。首先你可以觀察一下大致情況,使用:

  1. df.dtypes.value_counts() 

來了解你的dataframe的每項數(shù)據(jù)類型,然后再使用:

  1. df.select_dtypes(include=['float64''int64']) 

獲取一個僅由數(shù)值類型組成的sub-dataframe。

3. copy

如果你沒聽說過它的話,我不得強調(diào)它的重要性。輸入下面的命令:

  1. import pandas as pd 
  2. df1 = pd.DataFrame({ 'a':[0,0,0], 'b': [1,1,1]}) 
  3. df2 = df1 
  4. df2['a'] = df2['a'] + 1 
  5. df1.head() 

你會發(fā)現(xiàn)df1已經(jīng)發(fā)生了改變。這是因為df2 = df1并不是生成一個df1的復制品并把它賦值給df2,而是設(shè)定一個指向df1的指針。所以只要是針對df2的改變,也會相應地作用在df1上。為了解決這個問題,你既可以這樣做:

  1. df2 = df1.copy() 

也可以這樣做:

  1. from copy import deepcopy 
  2. df2 = deepcopy(df1) 

4. map

這個炫酷的命令讓你的數(shù)據(jù)轉(zhuǎn)換變得輕松。首先定義一個

dictionary,“key”是轉(zhuǎn)換前的舊值,而“values”是轉(zhuǎn)換后的新值。

  1. level_map = {1: 'high', 2: 'medium', 3: 'low'
  2. df['c_level'] = df['c'].map(level_map) 

幾個適用情景:把True、False,轉(zhuǎn)換成1、0(為了建模);定義級別;使用字典編碼。

5. 用不用apply?

如果我們想在現(xiàn)有幾列的基礎(chǔ)上生成一個新列,并一同作為輸入,那么有時apply函數(shù)會相當有幫助。

  1. def rule(x, y): 
  2.  if x == 'high' and y > 10: 
  3.  return 1 
  4.  else
  5.  return 0 
  6. df = pd.DataFrame({ 'c1':[ 'high' ,'high''low''low'], 'c2': [0, 23, 17, 4]}) 
  7. df['new'] = df.apply(lambda x: rule(x['c1'], x['c2']), axis = 1) 
  8. df.head() 

在上面的代碼中,我們定義了一個有兩個輸入變量的函數(shù),并依靠apply函數(shù)使其作用到列“c1”和“c2”上。

但是apply函數(shù)在有些情況下實在是太慢了。如果你是想計算“c1”和“c2”列的***值,你當然可以這樣去做:

  1. df['maximum'] = df.apply(lambda x: max(x['c1'], x['c2']), axis = 1) 

但你會發(fā)現(xiàn)相比于以下命令,apply實在是慢太多了:

  1. df['maximum'] = df[['c1','c2']].max(axis =1) 

結(jié)論:如果你可以采用其他內(nèi)置函數(shù)(他們一般速度更快),請不要使用apply。比如說,如果你想把“c”列的值近似取整,那么請用round(df[‘c’], 0)或df['c'],round(0)而不是上文的apply函數(shù)。

7. value counts

這個命令用于檢查值的分布。你想要檢查下“c”列中出現(xiàn)的值以及每個值所出現(xiàn)的頻率,可以使用:

  1. df['c'].value_counts( 

下面是一些有用的小技巧/參數(shù):

  • normalize = True:查看每個值出現(xiàn)的頻率而不是頻次數(shù)。
  • dropna = False: 把缺失值也保留在這次統(tǒng)計中。
  • sort = False: 將數(shù)據(jù)按照值來排序而不是按照出現(xiàn)次數(shù)排序。
  • df[‘c].value_counts().reset_index(): 將這個統(tǒng)計表轉(zhuǎn)換成pandas的dataframe并且進行處理。

8. 缺失值的數(shù)量

當構(gòu)建模型時,我們可能會去除包含過多缺失值或是全部是缺失值的行。這時可以使用.isnull()和.sum()來計算指定列缺失值的數(shù)量。

  1. import pandas as pd 
  2. import numpy as np 
  3. df = pd.DataFrame({ 'id': [1,2,3], 'c1':[0,0,np.nan], 'c2': [np.nan,1,1]}) 
  4. df = df[['id''c1''c2']] 
  5. df['num_nulls'] = df[['c1''c2']].isnull().sum(axis=1) 
  6. df.head() 

在SQL中我們可以使用 SELECT * FROM … WHERE ID in (‘A001’,‘C022’, …)來獲取含有指定ID的記錄。如果你也想在Pandas中做類似的事情,你可以使用:

  1. df_filter = df['ID'].isin(['A001','C022',...]) 
  2. df[df_filter] 

10. 基于分位數(shù)分組

面對一列數(shù)值,你想將這一列的值進行分組,比如說最前面的5%放入組別一,5-20%放入組別二,20%-50%放入組別三,***的50%放入組別四。當然,你可以使用pandas.cut,但你也可以使用下面這種選擇:

  1. import numpy as np 
  2. cut_points = [np.percentile(df['c'], i) for i in [50, 80, 95]] 
  3. df['group'] = 1 
  4. for i in range(3): 
  5.  df['group'] = df['group'] + (df['c'] < cut_points[i]) 
  6. or <= cut_points[i] 

這種方法的運行速度很快(并沒有使用到apply函數(shù))。

11. to_csv

這又是一個大家都會用的命令。我想在這里列出兩個小技巧。首先是

  1. print(df[:5].to_csv()) 

你可以使用這個命令打印出將要輸出文件中的前五行記錄。

另一個技巧是用來處理整數(shù)值和缺失值混淆在一起的情況。如果一列含有缺失值和整數(shù)值,那么這一列的數(shù)據(jù)類型會變成float而不是int。當導出表格時,你可以加上float_format=‘%.0f’以便將所有的浮點數(shù)近似成整數(shù)。當你想把所有列的輸出值都變成整數(shù)格式時,就可以使用這個技巧,這樣一來你就會告別所有數(shù)值后帶“.0”的煩惱。

原文標題:

10 PythonPandas tricks that make your work more efficient

原文鏈接:

https://towardsdatascience.com/10-python-pandas-tricks-that-make-your-work-more-efficient-2e8e483808ba

譯者簡介

 

[[264020]]

 

吳振東,法國洛林大學計算機與決策專業(yè)碩士?,F(xiàn)從事人工智能和大數(shù)據(jù)相關(guān)工作,以成為數(shù)據(jù)科學家為終生奮斗目標。來自山東濟南,不會開挖掘機,但寫得了Java、Python和PPT。

責任編輯:武曉燕 來源: 今日頭條
相關(guān)推薦

2024-02-26 16:40:58

2015-03-16 16:56:54

開發(fā)技巧應用孤島PaaS

2019-01-29 15:40:06

云應用開發(fā)云環(huán)境

2019-11-25 10:20:54

CSS代碼javascript

2009-10-27 09:09:06

Eclipse技巧

2011-08-29 09:33:48

2024-01-08 17:09:07

Python解釋器CPython

2018-06-20 11:00:06

云應用開發(fā)PaaS

2022-01-06 22:31:21

Python技巧代碼

2024-01-19 13:45:00

Pandas代碼深度學習

2023-07-26 07:41:53

Python線程狀態(tài)

2020-08-06 00:25:38

Python代碼開發(fā)

2024-06-24 00:05:00

Python代碼

2024-08-19 00:35:00

Pythondict遍歷列表推導式

2023-12-06 13:43:00

python代碼

2019-12-25 14:19:21

Python編程語言Java

2020-07-08 17:06:00

Python開發(fā)工具

2023-11-07 08:25:34

API接口參數(shù)驗證

2010-12-23 15:55:00

上網(wǎng)行為管理

2020-05-07 09:02:55

代碼Python開發(fā)
點贊
收藏

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