Conversione e analisi di dati categoriali

Analisi esplorativa dei dati in Python

George Boorman

Curriculum Manager, DataCamp

Anteprima dei dati

print(salaries.select_dtypes("object").head())
  Designation                 Experience    Employment_Status    Employee_Location    Company_Size
0 Data Scientist              Mid           FT                   DE                   L
1 Machine Learning Scientist  Senior        FT                   JP                   S
2 Big Data Engineer           Senior        FT                   GB                   M
3 Product Data Analyst        Mid           FT                   HN                   S
4 Machine Learning Engineer   Senior        FT                   US                   L
Analisi esplorativa dei dati in Python

Titoli di lavoro

print(salaries["Designation"].value_counts())
Data Scientist                              143
Data Engineer                               132
Data Analyst                                 97
Machine Learning Engineer                    41
Research Scientist                           16
Data Science Manager                         12
Data Architect                               11
Big Data Engineer                             8
Machine Learning Scientist                    8
...
Analisi esplorativa dei dati in Python

Titoli di lavoro

print(salaries["Designation"].nunique())
50
Analisi esplorativa dei dati in Python

Titoli di lavoro

Grafico a barre con i cinque ruoli più popolari: data scientist, data engineer, data analyst, machine learning engineer e research scientist

Analisi esplorativa dei dati in Python

Estrarre valore dalle categorie

  • Il formato attuale limita gli insight che possiamo ottenere

  • pandas.Series.str.contains()

    • Cerca in una colonna una stringa specifica o più stringhe
salaries["Designation"].str.contains("Scientist")
0       True
1       True
2      False
3      False
       ...  
604    False
605    False
606     True
Name: Designation, Length: 607, dtype: bool
Analisi esplorativa dei dati in Python

Trovare più frasi nelle stringhe

  • Parole di interesse: Machine Learning o AI
salaries["Designation"].str.contains("Machine Learning|AI")
0      False
1       True
2      False
3      False
       ...  
604    False
605    False
606     True
Name: Designation, Length: 607, dtype: bool
Analisi esplorativa dei dati in Python

Trovare più frasi nelle stringhe

  • Parole di interesse: qualunque inizi con Data
salaries["Designation"].str.contains("^Data")
0       True
1      False
2      False
3      False
       ...  
604     True
605     True
606    False
Name: Designation, Length: 607, dtype: bool
Analisi esplorativa dei dati in Python

Trovare più frasi nelle stringhe

job_categories = ["Data Science", "Data Analytics", 
                  "Data Engineering", "Machine Learning",
                  "Managerial", "Consultant"]
Analisi esplorativa dei dati in Python

Trovare più frasi nelle stringhe

data_science = "Data Scientist|NLP"

data_analyst = "Analyst|Analytics"
data_engineer = "Data Engineer|ETL|Architect|Infrastructure"
ml_engineer = "Machine Learning|ML|Big Data|AI"
manager = "Manager|Head|Director|Lead|Principal|Staff"
consultant = "Consultant|Freelance"
Analisi esplorativa dei dati in Python

Trovare più frasi nelle stringhe

conditions = [
    (salaries["Designation"].str.contains(data_science)),

(salaries["Designation"].str.contains(data_analyst)),
(salaries["Designation"].str.contains(data_engineer)),
(salaries["Designation"].str.contains(ml_engineer)),
(salaries["Designation"].str.contains(manager)),
(salaries["Designation"].str.contains(consultant)) ]
Analisi esplorativa dei dati in Python

Creare la colonna categoriale

salaries["Job_Category"] = 


Analisi esplorativa dei dati in Python

Creare la colonna categoriale

salaries["Job_Category"] = np.select(conditions, 


Analisi esplorativa dei dati in Python

Creare la colonna categoriale

salaries["Job_Category"] = np.select(conditions, 
                                     job_categories, 

Analisi esplorativa dei dati in Python

Creare la colonna categoriale

salaries["Job_Category"] = np.select(conditions, 
                                     job_categories, 
                                     default="Other")
Analisi esplorativa dei dati in Python

Anteprima delle categorie

print(salaries[["Designation", "Job_Category"]].head())
                  Designation      Job_Category
0              Data Scientist      Data Science
1  Machine Learning Scientist  Machine Learning
2           Big Data Engineer  Data Engineering
3        Product Data Analyst    Data Analytics
4   Machine Learning Engineer  Machine Learning
Analisi esplorativa dei dati in Python

Visualizzare la frequenza per categoria

sns.countplot(data=salaries, x="Job_Category")

plt.show()

Grafico a barre con il conteggio dei lavori per categoria

Analisi esplorativa dei dati in Python

Ayo berlatih!

Analisi esplorativa dei dati in Python

Preparing Video For Download...