Jak zamienić wartości inf na na w r
Możesz użyć następujących metod, aby zastąpić wartości Inf wartościami NA w R:
Metoda 1: Zamień Inf na NA w wektorze
x[is. infinite (x)] <- NA
Metoda 2: Zamień Inf na NA we wszystkich kolumnach ramki danych
df[sapply(df, is. infinite )] <- NA
Metoda 3: Zamień Inf na NA w określonych kolumnach ramki danych
df[c(' col1 ', ' col2 ')][sapply(df[c(' col1 ', ' col2 ')], is. infinite )] <- NA
W tym samouczku wyjaśniono, jak w praktyce używać każdej metody z następującą ramką danych:
#create data frame
df <- data. frame (team=c('A', 'A', 'A', 'A', 'B', 'B', 'B', 'B'),
position=c('G', 'G', 'F', 'F', 'G', 'G', 'F', 'F'),
points=c(10, 10, 8, 14, 15, 15, 17, 17))
#view data frame
df
team position points
1 AG 10
2 AG 10
3AF 8
4 AF 14
5 BG 15
6 BG 15
7 BF 17
8 BF 17
Przykład 1: Zamień Inf na NA w wektorze
Poniższy kod pokazuje jak zamienić wszystkie wartości Inf na wartości NA w wektorze:
#create vector with some Inf values
x <- c(4, 12, Lower, 8, Lower, 9, 12, 3, 22, Lower)
#replace Inf values with NA
x[is. infinite (x)] <- NA
#view updated vector
x
[1] 4 12 NA 8 NA 9 12 3 22 NA
Należy pamiętać, że wszystkie wartości Inf z oryginalnego wektora zostały zastąpione wartościami NA.
Przykład 2: Zamień Inf na NA we wszystkich kolumnach ramki danych
Poniższy kod pokazuje, jak zastąpić wartości Inf wartościami NA w każdej kolumnie ramki danych:
#create data frame
df <- data. frame (x=c(4, 5, 5, 4, Inf, 8, Inf),
y=c(10, Lower, Lower, 3, 5, 5, 8),
z=c(Inf, 5, 5, 6, 3, 12, 14))
#view data frame
df
X Y Z
1 4 10 Lower
2 5 Lower 5
3 5 Lower 5
4 4 3 6
5 Lower 5 3
6 8 5 12
7 Lower 8 14
#replace Inf values with NA values in all columns
df[sapply(df, is. infinite )] <- NA
#view updated data frame
df
X Y Z
1 4 10 NA
2 5 NA 5
3 5 NA 5
4 4 3 6
5 NA 5 3
6 8 5 12
7 NA 8 14
Należy pamiętać, że wartości Inf w każdej kolumnie ramki danych zostały zastąpione wartościami NA.
Przykład 3: Zamień Inf na NA w określonych kolumnach ramki danych
Poniższy kod pokazuje, jak zastąpić wartości Inf wartościami NA w określonych kolumnach ramki danych:
#create data frame
df <- data. frame (x=c(4, 5, 5, 4, Inf, 8, Inf),
y=c(10, Lower, Lower, 3, 5, 5, 8),
z=c(Inf, 5, 5, 6, 3, 12, 14))
#view data frame
df
X Y Z
1 4 10 Lower
2 5 Lower 5
3 5 Lower 5
4 4 3 6
5 Lower 5 3
6 8 5 12
7 Lower 8 14
#replace Inf values with NA values in columns 'x' and 'z' only
df[c(' x ', ' z ')][sapply(df[c(' x ', ' z ')], is. infinite )] <- NA
#view updated data frame
df
X Y Z
1 4 10 NA
2 5 Lower 5
3 5 Lower 5
4 4 3 6
5 NA 5 3
6 8 5 12
7 NA 8 14
Należy pamiętać, że wartości Inf w kolumnach „x” i „y” zostały zastąpione wartościami NA.
Jednak wartości Inf w kolumnie „y” pozostały nienaruszone.
Dodatkowe zasoby
Poniższe samouczki wyjaśniają, jak wykonywać inne typowe zadania w języku R:
Jak używać is.na w R
Jak używać na.omit w R
Jak zamienić puste miejsca na NA w R