Bekerja dengan Data Kategorikal di Python
Kasey Jones
Research Data Scientist
Dasar-dasar:
n - 1, di mana n adalah jumlah kategori-1 dipakai untuk nilai hilangKeterbatasan:
Ubah ke kategorikal dan urutkan menurut nama pabrikan
used_cars['manufacturer_name'] = used_cars['manufacturer_name'].astype("category")
Gunakan .cat.codes
used_cars['manufacturer_code'] = used_cars['manufacturer_name'].cat.codes
print(used_cars[['manufacturer_name', 'manufacturer_code']])
manufacturer_name manufacturer_code
0 Subaru 45
1 Subaru 45
2 Subaru 45
... ... ...
38526 Chrysler 8
38527 Chrysler 8

codes = used_cars['manufacturer_name'].cat.codes
categories = used_cars['manufacturer_name']
name_map = dict(zip(codes, categories))print(name_map)
{45: 'Subaru',
24: 'LADA',
12: 'Dodge',
...
}
Membuat kode:
used_cars['manufacturer_code'] = used_cars['manufacturer_name'].cat.codes
Kembali ke nilai awal:
used_cars['manufacturer_code'].map(name_map)
0 Acura
1 Acura
2 Acura
...
Cari semua tipe bodi yang memuat "van":
# Kode dari pelajaran sebelumnya:
used_cars["body_type"].str.contains("van", regex=False)
Buat pengodean boolean:
used_cars["van_code"] = np.where( used_cars["body_type"].str.contains("van", regex=False), 1, 0)used_cars["van_code"].value_counts()
0 34115
1 4416
Name: van_code, dtype: int64
Bekerja dengan Data Kategorikal di Python