Test A/B e segmentazione

Analizzare campagne di marketing con pandas

Jill Rosok

Data Scientist

Non dimenticare la segmentazione!

shutterstock_379530769.jpg

Analizzare campagne di marketing con pandas

Test di personalizzazione per lingua

for language in np.unique(marketing['language_displayed'].values):
    print(language)


Analizzare campagne di marketing con pandas

Isola i dati rilevanti

for language in np.unique(marketing['language_displayed'].values):
    print(language)

    language_data = marketing[(marketing['marketing_channel'] == 'Email') & 
                              (marketing['language_displayed'] == language)]                              
Analizzare campagne di marketing con pandas

Isola gli iscritti

for language in np.unique(marketing['language_displayed'].values):
    print(language)

    language_data = marketing[(marketing['marketing_channel'] == 'Email') & 
                              (marketing['language_displayed'] == language)]

    subscribers = language_data.groupby(['user_id', 'variant'])['converted']\
                                                                      .max()
Analizzare campagne di marketing con pandas

Isola control e personalization

for language in np.unique(marketing['language_displayed'].values):
    print(language)

    language_data = marketing[(marketing['marketing_channel'] == 'Email') & 
                              (marketing['language_displayed'] == language)]

    subscribers = language_data.groupby(['user_id', 'variant'])['converted']\
                                                                      .max()
    subscribers = pd.DataFrame(subscribers.unstack(level=1)) 
    control = subscribers['control'].dropna()
    personalization = subscribers['personalization'].dropna()  
Analizzare campagne di marketing con pandas

For completo

for language in np.unique(marketing['language_displayed'].values):
    print(language)

    language_data = marketing[(marketing['marketing_channel'] == 'Email') & 
                              (marketing['language_displayed'] == language)]

    subscribers = language_data.groupby(['user_id', 'variant'])['converted']\
                                                                      .max()
    subscribers = pd.DataFrame(subscribers.unstack(level=1)) 
    control = subscribers['control'].dropna()
    personalization = subscribers['personalization'].dropna()  

    print('lift:', lift(control, personalization))
    print('t-statistic:', stats.ttest_ind(control, personalization), '\n\n')
Analizzare campagne di marketing con pandas

Risultati

Arabic
lift: 50.0%
t-statistic: TtestResult(statistic=-0.58, pvalue=0.58, df=8.0) 

English
lift: 39.0%
t-statistic: TtestResult(statistic=-2.22, pvalue=0.03, df=486.0) 

German
lift: -1.62%
t-statistic: TtestResult(statistic=0.19, pvalue=0.85, df=42.0) 

Spanish
lift: 166.67%
t-statistic: TtestResult(statistic=-2.36, pvalue=0.04, df=10.0) 
Analizzare campagne di marketing con pandas

¡Vamos a practicar!

Analizzare campagne di marketing con pandas

Preparing Video For Download...