Cara mengganti nilai pada data frame di r (dengan contoh)
Anda dapat menggunakan sintaks berikut untuk mengganti nilai tertentu dalam bingkai data di R dengan nilai baru:
df[df == ' Old Value '] <- ' New value '
Anda dapat menggunakan sintaks berikut untuk mengganti salah satu dari banyak nilai dalam bingkai data dengan nilai baru:
df[df == ' Old Value 1 ' | df == ' Old Value 2 '] <- ' New value '
Dan Anda bisa menggunakan sintaks berikut untuk mengganti nilai tertentu di kolom tertentu pada bingkai data dengan nilai baru:
df['column1'][df['column1'] == ' Old Value '] <- ' New value '
Contoh berikut menunjukkan cara menggunakan sintaksis ini dalam praktiknya.
Contoh 1: Ganti nilai tertentu di seluruh bingkai data
Kode berikut menunjukkan cara mengganti nilai tertentu dengan nilai baru di seluruh bingkai data:
#create data frame df <- data. frame (a = as. factor (c(1, 5, 7, 8)), b = c('A', 'B', 'C', 'D'), c = c(14, 14, 19, 22), d = c(3, 7, 14, 11)) #view data frame df abcd 1 1 To 14 3 2 5 B 14 7 3 7 C 19 14 4 8 D 22 11 #replace '14' with '24' across entire data frame df[df == 14] <- 24 #view updated data frame df abcd 1 1 To 24 3 2 5 B 24 7 3 7 C 19 24 4 8 D 22 11
Contoh 2: Ganti salah satu dari beberapa nilai di seluruh bingkai data
Kode berikut menunjukkan cara mengganti salah satu dari beberapa nilai dengan nilai baru di seluruh bingkai data:
#create data frame df <- data. frame (a = as. factor (c(1, 5, 7, 8)), b = c('A', 'B', 'C', 'D'), c = c(14, 14, 19, 22), d = c(3, 7, 14, 11)) #view data frame df abcd 1 1 To 14 3 2 5 B 14 7 3 7 C 19 14 4 8 D 22 11 #replace '14' and '19' with '24' across entire data frame df[df == 14 | df == 19] <- 24 #view updated data frame df abcd 1 1 To 24 3 2 5 B 24 7 3 7 C 24 24 4 8 D 22 11
Contoh 3: Ganti nilai di kolom tertentu pada bingkai data
Kode berikut menunjukkan cara mengganti nilai tertentu dengan nilai baru di kolom tertentu pada bingkai data:
#create data frame df <- data. frame (a = as. factor (c(1, 5, 7, 8)), b = c('A', 'B', 'C', 'D'), c = c(14, 14, 19, 22), d = c(3, 7, 14, 11)) #view data frame df abcd 1 1 To 14 3 2 5 B 14 7 3 7 C 19 14 4 8 D 22 11 #replace '14' in column c with '24' df['c'][df['c'] == 14] <- 24 #view updated data frame df abcd 1 1 To 24 3 2 5 B 24 7 3 7 C 19 14 4 8 D 22 11
Contoh 4: Gantikan nilai variabel faktor dalam bingkai data
Jika Anda mencoba mengganti nilai tertentu dari variabel faktor, Anda akan menemukan pesan peringatan berikut:
#create data frame df <- data. frame (a = as. factor (c(1, 5, 7, 8)), b = c('A', 'B', 'C', 'D'), c = c(14, 14, 19, 22), d = c(3, 7, 14, 11)) #attempt to replace '1' with '24' in column a df['a'][df['a'] == 1] <- 24 Warning message: In `[<-.factor`(`*tmp*`, thisvar, value = 24): invalid factor level, NA generated abcd 1 <NA> A 14 3 2 5 B 14 7 3 7 C 19 14 4 8 D 22 11
Untuk menghindari peringatan ini, Anda harus terlebih dahulu mengubah variabel faktor menjadi variabel numerik:
#convert column a to numeric df$a <- as. numeric (as. character (df$a)) #replace '1' with '24' in column a df['a'][df['a'] == 1] <- 24 #view updated data frame df abcd 1 24 A 14 3 2 5 B 14 7 3 7 C 19 14 4 8 D 22 11
Sumber daya tambahan
Bagaimana cara mengganti NA dengan string di R
Bagaimana cara memasukkan semua nilai yang hilang di R