Course introduction

Working with Categorical Data in Python

Kasey Jones

Research Data Scientist

What does it mean to be "categorical"?

Categorical

  • Finite number of groups (or categories)
  • These categories are usually fixed or known (eye color, hair color, etc.)
  • Known as qualitative data

Numerical

  • Known as quantitative data
  • Expressed using a numerical value
  • Is usually a measurement (height, weight, IQ, etc.)
Working with Categorical Data in Python

Ordinal vs. nominal variables

Ordinal

  • Categorical variables that have a natural order

Survey responses often range from strongly disagree up to strongly agree. These categories have a logical order to them.

Nominal

  • Categorical variables that cannot be placed into a natural order

Sometimes categories, such as selecting a color from a list ("Blue", "Green", "Red", "Yellow", "purple"), do not have a logical order.

Working with Categorical Data in Python

Our first dataset

adult.info()
<class 'pandas.core.frame.DataFrame'>
RangeIndex: 32561 entries, 0 to 32560
Data columns (total 15 columns):
 #   Column           Non-Null Count  Dtype 
 --  ------           --------------  ----- 
 0   Age              32561 non-null  int64 
 1   Workclass        32561 non-null  object
 2   fnlgwt           32561 non-null  int64 
 3   Education        32561 non-null  object
 4   Education Num    32561 non-null  int64 
 5   Marital Status   32561 non-null  object
...
1 https://www.kaggle.com/uciml/adult-census-income
Working with Categorical Data in Python

Using describe

adult["Marital Status"].describe()
count                   32561
unique                      7
top        Married-civ-spouse
freq                    14976
Name: Marital Status, dtype: object
Working with Categorical Data in Python

Using value counts

adult["Marital Status"].value_counts()
 Married-civ-spouse       14976
 Never-married            10683
 Divorced                  4443
 Separated                 1025
 Widowed                    993
 Married-spouse-absent      418
 Married-AF-spouse           23
Name: Marital Status, dtype: int64
Working with Categorical Data in Python

Using value counts with normalize

adult["Marital Status"].value_counts(normalize=True)
 Married-civ-spouse       0.459937
 Never-married            0.328092
 Divorced                 0.136452
 Separated                0.031479
 Widowed                  0.030497
 Married-spouse-absent    0.012837
 Married-AF-spouse        0.000706
Name: Marital Status, dtype: float64
Working with Categorical Data in Python

Knowledge check

Working with Categorical Data in Python

Preparing Video For Download...