Nieuwe kolommen maken

Data manipulatie in Julia

Katerina Zahradova

Instructor

Kolommen vs. rijen

Kolom

  • Eén getal voor alle rijen
  • Bijv. gemiddelde, mediaan, som, ...

Rijen

  • Waarden hangen per rij van de data af

=> gebruik ByRow()

Data manipulatie in Julia

Flipperlengte in inches

# Converteer mm naar inches
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
...
Data manipulatie in Julia

Verhouding snaveldiepte/-lengte

# Selecteer kolommen en bereken hun verhouding
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
...
Data manipulatie in Julia

Nieuwe kolom uit een vector

# Vector id_vec die we willen toevoegen


# Met [] en : penguins[:, :id_colon] = id_vec
# Met [] en ! penguins[!, :id_exclamation] = id_vec
# Met . penguins.id_dot = id_vec
Data manipulatie in Julia

Kopie of niet

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

# Eerste element wijzigen
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
...
Data manipulatie in Julia

Kopie of niet

penguins[:, :id_colon] = id_vec        # kopieert waarden naar de DataFrame
penguins[!, :id_exclamation] = id_vec  # verwijst naar id_vec
penguins.id_dot = id_vec               # verwijst naar id_vec

# Eerste element wijzigen
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
...
Data manipulatie in Julia

Laten we oefenen!

Data manipulatie in Julia

Preparing Video For Download...