A/B-testen & segmentatie

Marketingcampagnes analyseren met pandas

Jill Rosok

Data Scientist

Vergeet segmentatie niet!

shutterstock_379530769.jpg

Marketingcampagnes analyseren met pandas

Personalisatietest gesegmenteerd op taal

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


Marketingcampagnes analyseren met pandas

Isoleer de relevante data

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

    language_data = marketing[(marketing['marketing_channel'] == 'Email') & 
                              (marketing['language_displayed'] == language)]                              
Marketingcampagnes analyseren met pandas

Isoleer abonnees

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()
Marketingcampagnes analyseren met pandas

Isoleer control en personalisatie

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()  
Marketingcampagnes analyseren met pandas

Volledige for-lus

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')
Marketingcampagnes analyseren met pandas

Resultaten

Arabic
lift: 50.0%
t-statistic: Ttest_indResult(statistic=-0.58, pvalue=0.58) 

English
lift: 39.0%
t-statistic: Ttest_indResult(statistic=-2.22, pvalue=0.03) 

German
lift: -1.62%
t-statistic: Ttest_indResult(statistic=0.19, pvalue=0.85) 

Spanish
lift: 166.67%
t-statistic: Ttest_indResult(statistic=-2.36, pvalue=0.04) 
Marketingcampagnes analyseren met pandas

Laten we oefenen!

Marketingcampagnes analyseren met pandas

Preparing Video For Download...