欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解Pandas 處理缺失值指令大全

 更新時間:2020年07月30日 10:39:25   作者:fitness suite  
這篇文章主要介紹了詳解Pandas 處理缺失值指令大全,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧

前言

運用pandas 庫對所得到的數(shù)據(jù)進行數(shù)據(jù)清洗,復(fù)習一下相關(guān)的知識。

1 數(shù)據(jù)清洗

1.1 處理缺失數(shù)據(jù)

對于數(shù)值型數(shù)據(jù),分為缺失值(NAN)和非缺失值,對于缺失值的檢測,可以通過Python中pandas庫的Series類對象的isnull方法進行檢測。

import pandas as pd
import numpy as np
string_data = pd.Series(['Benzema', 'Messi', np.nan, 'Ronaldo'])
string_data.isnull()

對于缺失值,除了np.nan來表示,還可以用None來表示缺失值

string_data = None

1.2 濾除掉缺失數(shù)據(jù)

1.2.1 對于Series

使用dropna方法將NAN的數(shù)據(jù)過濾掉。

from numpy import nan as NA
import pandas as pd
data = pd.Series([1,NA,4.5,NA,5])
data.dropna()

另一種方法是使用布爾值索引對NAN數(shù)據(jù)進行過濾:

data[data.notnull()]

1.2.2 對于DataFrame

dropna()方法對于DataFrame的數(shù)據(jù)來說,會將含有NAN數(shù)據(jù)的行全部扔掉。

data = pd.DataFrame([[1., 6.5, 3.], [1., NA, NA],
           [NA, NA, NA], [NA, 6.5, 3.]])
data
data.dropna()

如果只想刪除掉那些行中全部為NAN數(shù)據(jù)的DataFrame,通過設(shè)置dropna()方法中的參數(shù)how即可。

data.dropna(how = 'all')

如果操作對象變?yōu)榱?代碼如下:

data[4] = NA
data
data.dropna(axis=1, how = 'all')

如果想留下其中的一部分數(shù)據(jù),則可以設(shè)置thresh參數(shù):

df = pd.DataFrame(np.random.randn(7, 3))
df.iloc[:4, 1] = NA
df.iloc[:2, 2] = NA
df
df.dropna(thresh = 2)

thresh = n,參數(shù)n相當于保留至少含有n個非NA的行

1.3 填充缺失數(shù)據(jù)

fillna(n),n替換掉NA

df = pd.DataFrame(np.random.randn(7, 3))
df.fillna(0)

如果填充格式是字典,fillna({0:n1,1:n2}),將列0的NA填充為 n1,將列1的NA填充為 n2。

df.fillna({{1 : 0.2,2 : 0.3}})

直接填充df的NA值,直接改變df,不需要命名新的變量。

df.fillna(0, inplace = True)

2 數(shù)據(jù)轉(zhuǎn)換

2.1 移除重復(fù)數(shù)據(jù)

data = pd.DataFrame({'k1': ['one', 'two'] * 3 + ['two'],
           'k2': [1, 1, 2, 3, 3, 4, 4]})
data.duplicated()

返回的是每一行的重復(fù)結(jié)果,不重復(fù)是False,重復(fù)是True。

如果要去除重復(fù)的行,代碼如下:

data.drop_duplicates()

如果操作對象為列,在duplicated方法中指定參數(shù)即可。

data['k3'] = range(7)
data.duplicated(['k1'])

返回的是 k1 列中重復(fù)的元素。

對于drop_duplicates()方法來說,去除掉的是重復(fù)數(shù)據(jù)的后者。比如說序號為0,1的數(shù)據(jù)重復(fù),方法刪除掉index = 1的行。如果想要刪除前者,只需要指定參數(shù) last即可:

data.drop_duplicates(['k1'], keep = 'last')

2.2 與映射相結(jié)合

map函數(shù)的使用方法

list(map(lambda x : 2 * x , range(10)))

2.3 替換

使用的是replace 方法,replace有兩個參數(shù),前者是被替換的數(shù),后者是替換的數(shù),參數(shù)格式可以是列表,也可以是字典

data = pd.Series([1., -999., 2., -999., -1000., 3.])
data.replace(-999.0, np.nan) #替換單個值
data.replace([-999.0, -1000.0], np.nan) #用一個值替換多個值
data.replace([-999.0, -1000.0],[np.nan, 0]) # 用不同值替換不同值
data.replace({-999.0 : 0, -1000.0 : np.nan}) # 格式為字典

2.4 創(chuàng)建數(shù)據(jù)的修改版

rename方法可以創(chuàng)建數(shù)據(jù)的修改版,而不必在原數(shù)據(jù)上進行修改。

data.rename(index=str.title, columns=str.upper)

還可以使用字典的格式,對index, columns 進行改變。

data.rename(index = {'OHIO': 'INDIANA'}, columns = {'three': 'peekaboo'})

這樣的重命名并不對原數(shù)據(jù)進行修改,如果想要直接改變data, 如上,參數(shù)inplace = True即可。

data.rename(index = {'OHIO': 'INDIANA'}, columns = {'three': 'peekaboo'}, inplace = True)
data

這樣就改變了data。

2.5 計算指標\啞變量

用于機器學(xué)習中,對定類數(shù)據(jù)的轉(zhuǎn)化,用于將df中的object對象轉(zhuǎn)化為One-hot編碼,消除了數(shù)字間的比較大小問題。

df = pd.DataFrame({'key': ['b', 'b', 'a', 'c', 'a', 'b'],
          'data1': range(6)})
pd.get_dummies(df['key']) # 分解了key 列,分開了三個屬性

如果想在分開的屬性前面加上前綴的話,設(shè)定prefix 參數(shù)即可實現(xiàn)該功能,可以將其與原始數(shù)據(jù)合并在一起。

dummies = pd.get_dummies(df['key'], prefix = 'key')
df_with_dummies = df['data1'].join(dummies)
df_with_dummies

到此這篇關(guān)于詳解Pandas 處理缺失值指令大全 的文章就介紹到這了,更多相關(guān)Pandas 處理缺失值內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Python中scatter散點圖及顏色整理大全

    Python中scatter散點圖及顏色整理大全

    python自帶的scatter函數(shù)參數(shù)中顏色和大小可以輸入列表進行控制,即可以讓不同的點有不同的顏色和大小,下面這篇文章主要給大家介紹了關(guān)于Python中scatter散點圖及顏色整理大全的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • Pandas實現(xiàn)列(column)排序的幾種方法

    Pandas實現(xiàn)列(column)排序的幾種方法

    Pandas是一種高效的數(shù)據(jù)處理庫,在數(shù)據(jù)處理過程中,咱們經(jīng)常需要將列按照一定的要求進行排序,本文就來介紹一下Pandas實現(xiàn)列(column)排序的幾種方法,感興趣的可以了解一下
    2023-11-11
  • python pandas loc 布爾索引示例說明

    python pandas loc 布爾索引示例說明

    loc跟iloc的區(qū)別,首先loc是location的意思,和iloc中i的意思是指integer,所以它只接受整數(shù)作為參數(shù),詳情見下面
    2022-03-03
  • 一款開源的Python一鍵搶票神器詳細配置

    一款開源的Python一鍵搶票神器詳細配置

    大家好,本篇文章主要講的是一款開源的Python一鍵搶票神器,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • python3中的類繼承你真的了解嗎

    python3中的類繼承你真的了解嗎

    這篇文章主要為大家詳細介紹了python3中的類繼承,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-03-03
  • python簡單貪吃蛇開發(fā)

    python簡單貪吃蛇開發(fā)

    這篇文章主要為大家詳細介紹了python簡單貪吃蛇開發(fā),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-01-01
  • 數(shù)據(jù)庫操作入門PyMongo?MongoDB基本用法

    數(shù)據(jù)庫操作入門PyMongo?MongoDB基本用法

    這篇文章主要為大家介紹了數(shù)據(jù)庫操作入門PyMongo MongoDB基本用法示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-11-11
  • Python三元運算與lambda表達式實例解析

    Python三元運算與lambda表達式實例解析

    這篇文章主要介紹了Python三元運算與lambda表達式實例解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友可以參考下
    2019-11-11
  • 教你用scrapy框架爬取豆瓣讀書Top250的書類信息

    教你用scrapy框架爬取豆瓣讀書Top250的書類信息

    這篇文章主要介紹了教你用scrapy框架爬取豆瓣讀書Top250的書類信息,文中提供了解決思路和部分實現(xiàn)代碼,需要的朋友可以參考下
    2023-03-03
  • 使用Python實現(xiàn)遺傳算法的詳細步驟

    使用Python實現(xiàn)遺傳算法的詳細步驟

    遺傳算法是模仿自然界生物進化機制發(fā)展起來的隨機全局搜索和優(yōu)化方法,它借鑒了達爾文的進化論和孟德爾的遺傳學(xué)說,其本質(zhì)是一種高效、并行、全局搜索的方法,本文給大家介紹了使用Python實現(xiàn)遺傳算法的詳細步驟,需要的朋友可以參考下
    2023-11-11

最新評論