Menghapus dan memindahkan kolom

Manipulasi Data di Julia

Katerina Zahradova

Instructor

Cara memilih sebagian besar kolom

# Memilih semua kolom dari chocolates kecuali kolom review_date
select(chocolates, :company, :bean_origin, :REF, :cocoa,
        :company_location, :ratings, :bean_type, :bean_location)
ArgumentError: column name "ratings" not found in the data frame; 
    existing most similar names are: "rating"
...
Manipulasi Data di Julia

Operator Not()

# Memilih semua kolom dari chocolates kecuali kolom review_date
select(chocolates, Not(:review_date))
1795×9 DataFrame 
Row company  bean_origin REF   cocoa   company_location rating  bean_type bean_location
    String   String      Int64 Float64 String31         Float64 String31? String31?
______________________________________________________________________________________
1   A. Morin Agua Grande 1876  63.0    France           3.75    Sao Tome
...
Manipulasi Data di Julia

Jebakan select() dan Not()

# Menghapus kolom yang sama dua kali
select!(chocolates, Not(:review_date))

# Beberapa baris kode kemudian ...

select(chocolates, Not(:review_date))
ArgumentError: column name :review_date not found in the data frame
Manipulasi Data di Julia

Menghapus kolom yang tidak ada dengan aman

# Menggunakan Cols
select(chocolates, Not(Cols(==("review_date"))))
1795×9 DataFrame 
Row company  bean_origin REF   cocoa   company_location rating  bean_type bean_location
    String   String      Int64 Float64 String31         Float64 String31? String31?
...
# Menggunakan regex
select(chocolates, Not(r"review\_date"))
1795×9 DataFrame 
Row company  bean_origin REF   cocoa   company_location rating  bean_type bean_location
    String   String      Int64 Float64 String31         Float64 String31? String31?
...
Manipulasi Data di Julia

Mengubah urutan kolom

# Cokelat terpilih
first(chocolates)
1795x5 DataFrame
Row  company   review_date  cocoa    rating   bean_location 
     String    Int64        Float64  Float64  String31?
__________________________________________________________
1    A. Morin  2016         63.0     3.75     Sao Tome
Manipulasi Data di Julia

Pindahkan ke kiri

# Memindahkan cocoa ke kiri
select(chocolates, :cocoa, :)
1795x5 DataFrame
Row  cocoa    company   review_date  rating   bean_location 
     Float64  String    Int64        Float64  String31?
__________________________________________________________
1    63.0     A. Morin  2016         3.75     Sao Tome
...
Manipulasi Data di Julia

Pindahkan keduanya ke kiri

# Memindahkan cocoa dan rating ke kiri
select(chocolates, :cocoa, :rating, :)
1795x5 DataFrame

Row  cocoa    rating   company   review_date  bean_location 
     Float64  Float64  String    Int64        String31?
__________________________________________________________
1    63.0     3.75     A. Morin  2016         Sao Tome
...
Manipulasi Data di Julia

Pindahkan ke kanan

# Memindahkan company ke kanan
select(chocolates, Not(:company), :company)
1795x5 DataFrame
Row  review_date  cocoa    rating   bean_location  company
     Int64        Float64  Float64  String31?      String
__________________________________________________________
1    2016         63.0     3.75     Sao Tome       A. Morin
...
Manipulasi Data di Julia

Pindahkan semuanya

# Menggabungkan dua perpindahan
select(chocolates, :cocoa, :rating, Not(:company), :company)
1795x5 DataFrame
Row cocoa    rating   bean_location  review_date  company 
    Float64  Float64  String31       Int64        String
__________________________________________________________
1   63.0     3.75     Sao Tome       2016         A. Morin
...
Manipulasi Data di Julia

Pindah dan hapus sekaligus

# Ubah urutan dan hapus review_date
# Gabungkan dua perpindahan
select(chocolates, :cocoa, :rating, Not([:company, :review_date]), :company)
1795x4 DataFrame
Row cocoa    rating   bean_location  company 
    Float64  Float64  String31       String
__________________________________________________________
1   63.0     3.75     Sao Tome       A. Morin
...
Manipulasi Data di Julia

Cheat sheet

Menghapus kolom:

# Hapus col1 dan col 2
select(df, Not([:col1, "col 2"]))

Menghapus kolom dengan aman:

# Hapus col1 dan col 2 yang mungkin tidak ada
select(df, Not(r"col1"), Not(Cols(==("col 2"))))

Memindahkan kolom ke kiri

# Pindahkan col1 dan col 2 ke kiri
select(df, :col1, "col 2", :)

Memindahkan kolom ke kanan

# Pindahkan col1 dan col 2 ke kanan
select(df, Not([:col1, "col 2"]) ,:col1, "col 2")
Manipulasi Data di Julia

Ayo berlatih!

Manipulasi Data di Julia

Preparing Video For Download...