Come eliminare righe con valori nan in pandas
Spesso potresti voler rimuovere righe contenenti valori NaN in un DataFrame panda. Fortunatamente, questo è facile da fare utilizzando la funzione dropna() di panda.
Questo tutorial mostra diversi esempi di utilizzo di questa funzione sui seguenti DataFrame panda:
import numpy as np import scipy.stats as stats #create DataFrame with some NaN values df = pd.DataFrame({'rating': [np.nan, 85, np.nan, 88, 94, 90, 76, 75, 87, 86], 'points': [np.nan, 25, 14, 16, 27, 20, 12, 15, 14, 19], 'assists': [5, 7, 7, np.nan, 5, 7, 6, 9, 9, 5], 'rebounds': [11, 8, 10, 6, 6, 9, 6, 10, 10, 7]}) #view DataFrame df rating points assists rebounds 0 NaN NaN 5.0 11 1 85.0 25.0 7.0 8 2 NaN 14.0 7.0 10 3 88.0 16.0 NaN 6 4 94.0 27.0 5.0 6 5 90.0 20.0 7.0 9 6 76.0 12.0 6.0 6 7 75.0 15.0 9.0 10 8 87.0 14.0 9.0 10 9 86.0 19.0 5.0 7
Esempio 1: Elimina righe con valori NaN
Possiamo usare la seguente sintassi per rimuovere tutte le righe contenenti valori NaN:
df. dropna ()
rating points assists rebounds
1 85.0 25.0 7.0 8
4 94.0 27.0 5.0 6
5 90.0 20.0 7.0 9
6 76.0 12.0 6.0 6
7 75.0 15.0 9.0 10
8 87.0 14.0 9.0 10
9 86.0 19.0 5.0 7
Esempio 2: rimuovere le righe con tutti i valori NaN
Possiamo utilizzare la seguente sintassi per rimuovere tutte le righe contenenti tutti i valori NaN in ciascuna colonna:
df. dropna (how=' all ') rating points assists rebounds 0 NaN NaN 5.0 11 1 85.0 25.0 7.0 8 2 NaN 14.0 7.0 10 3 88.0 16.0 NaN 6 4 94.0 27.0 5.0 6 5 90.0 20.0 7.0 9 6 76.0 12.0 6.0 6 7 75.0 15.0 9.0 10 8 87.0 14.0 9.0 10 9 86.0 19.0 5.0 7
Non c’erano righe con tutti i valori NaN in questo particolare DataFrame, quindi nessuna riga è stata eliminata.
Esempio 3: eliminare le righe al di sotto di una determinata soglia
Possiamo utilizzare la seguente sintassi per rimuovere tutte le righe che non hanno almeno un certo numero di valori non NaN:
df. dropna (thresh= 3 ) rating points assists rebounds 1 85.0 25.0 7.0 8 2 NaN 14.0 7.0 10 3 88.0 16.0 NaN 6 4 94.0 27.0 5.0 6 5 90.0 20.0 7.0 9 6 76.0 12.0 6.0 6 7 75.0 15.0 9.0 10 8 87.0 14.0 9.0 10 9 86.0 19.0 5.0 7
La prima riga del DataFrame originale non conteneva almeno 3 valori non NaN, quindi quella era l’unica riga rimossa.
Esempio 4: elimina una riga con valori Nan in una colonna specifica
Possiamo utilizzare la seguente sintassi per rimuovere tutte le righe che hanno un valore NaN in una colonna specifica:
df. dropna (subset=[' assists ']) rating points assists rebounds 0 NaN NaN 5.0 11 1 85.0 25.0 7.0 8 2 NaN 14.0 7.0 10 4 94.0 27.0 5.0 6 5 90.0 20.0 7.0 9 6 76.0 12.0 6.0 6 7 75.0 15.0 9.0 10 8 87.0 14.0 9.0 10 9 86.0 19.0 5.0 7
Esempio 5: reimpostare l’indice dopo aver eliminato le righe con NaN
Possiamo utilizzare la seguente sintassi per reimpostare l’indice del DataFrame dopo aver eliminato le righe con valori NaN:
#drop all rows that have any NaN values df = df. dropna () #reset index of DataFrame df = df. reset_index (drop=True) #view DataFrame df rating points assists rebounds 0 85.0 25.0 7.0 8 1 94.0 27.0 5.0 6 2 90.0 20.0 7.0 9 3 76.0 12.0 6.0 6 4 75.0 15.0 9.0 10 5 87.0 14.0 9.0 10 6 86.0 19.0 5.0 77
Puoi trovare la documentazione completa per la funzione dropna() qui .