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

Tambahkan komentar

Alamat email Anda tidak akan dipublikasikan. Ruas yang wajib ditandai *