Membuat kolom baru

Manipulasi Data di Julia

Katerina Zahradova

Instructor

Kolom vs. baris

Kolom

  • Satu angka untuk semua baris
  • Mis.: mean, median, sum, ...

Baris

  • Nilai bergantung pada data di tiap baris

=> gunakan ByRow()

Manipulasi Data di Julia

Panjang sirip ke inci

# Konversi mm ke inci
transform(penguins, :flipper_length_mm => ByRow(x -> x/25.4) => :flipper_length_inch)
333x8 DataFrame
Row species   island    ...  body_mass_g  sex      flipper_lenght_inch
    String15  String15  ...  Int64        String7  Float64 
___________________________________________________________________
1   Adelie    Torgersen ...  3750         MALE     7.12598
2   Adelie    Torgersen ...  3800         FEMALE   7.32283
...
Manipulasi Data di Julia

Rasio kedalaman dan panjang culmen

# Pilih kolom dan hitung rasionya
select(penguins,:culmen_depth_mm, :culmen_length_mm, 
   [:culmen_depth_mm, :culmen_length_mm] => ByRow((x, y) -> x/y) => :culmen_ratio)
333x3 DataFrame
Row  culmen_depth_mm  culmen_length_mm  culmen_ratio
     Float64          Float64           Float64
_____________________________________________________
1    18.7             39.1              0.478261
2    17.4             39.5              0.440506
...
Manipulasi Data di Julia

Kolom baru dari sebuah vektor

# Vektor id_vec yang akan ditambahkan


# Menggunakan [] dan : penguins[:, :id_colon] = id_vec
# Menggunakan [] dan ! penguins[!, :id_exclamation] = id_vec
# Menggunakan . penguins.id_dot = id_vec
Manipulasi Data di Julia

Salin atau tidak

penguins[:, :id_colon] = id_vec
penguins[!, :id_exclamation] = id_vec
penguins.id_dot = id_vec

# Ubah elemen pertama
id_vec[1] = 27
select(penguins, :species, r"id")
333x4 DataFrame
Row  species   id_colon  id_exclamation  id_dot
     String15  Int64     Int64           Int64
_____________________________________________________
1    Adelie    25        27              27
...
Manipulasi Data di Julia

Salin atau tidak

penguins[:, :id_colon] = id_vec        # menyalin nilai ke DataFrame
penguins[!, :id_exclamation] = id_vec  # mereferensikan id_vec
penguins.id_dot = id_vec               # mereferensikan id_vec

# Ubah elemen pertama
id_vec[1] = 27
select(penguins, :species, r"id")
333x4 DataFrame
Row  species   id_colon  id_exclamation  id_dot
     String15  Int64     Int64           Int64
_____________________________________________________
1    Adelie    25        27              27
...
Manipulasi Data di Julia

Ayo berlatih!

Manipulasi Data di Julia

Preparing Video For Download...