Context¶
In certain types of businesses, customer visits can be fairly frequent, on daily or weekly basis. Keeping customers maintain their streak can generate constant revenue, which is obviously sweet to business. Marketing professinals would find out what drives customers start their streak. To this end, we may try to figure out what happened on their first day/week. This blog shows you how to locate the first day.
This notebook is available on GitHub.
Prepare Dummy Data¶
Here we create dummy data for demonstration. Assume a customer visited on the following dates saved in a Pandas series. The current streak started on Feb 1, 2000.
import pandas as pd
dates1 = pd.Series(pd.date_range('2000-01-20', '2000-01-30', freq='2D'))
dates2 = pd.Series(pd.date_range('2000-02-01', '2000-02-10', freq='D'))
dates = pd.concat([dates1, dates2]).reset_index(drop=True)
dates
dates.shift()
Can you see that all the rows are shifted downwards a row? The new first row is filled with a missing value and the old last row disappeared. What if you want it move upwards? For that you need to give it a negative step:
dates.shift(-1)
Operation¶
By now, you probably have already the idea in your mind of what I will do next. After shift, the dates in streak differ in one day, aka, time basis, in the same row. To make this clear, we put the serieses before and after the shifting in one single dataframe. Focus on Row 6.
dates_df = pd.DataFrame(
{'before': dates, 'after_downwards': dates.shift(), 'after_upwards': dates.shift(-1)},
columns=['before', 'after_downwards', 'after_upwards']
)
dates_df
Therefore querying the day difference can return the streak area or the non streak area.
Streak area:¶
dates.loc[(dates.shift(-1) - dates).dt.days == 1]
Non-streak area:¶
dates.loc[(dates - dates.shift()).dt.days != 1]
The intersection is of course the first day!
dates.loc[((dates.shift(-1) - dates).dt.days == 1) & ((dates - dates.shift()).dt.days != 1)]
Conclusion¶
This blog shows you how to query the first day of a treak, which is useful for marketing experts to further investigate the drivers for customer's consecutive visits and therefore be able to make the success story bigger.
Note this method can be extended to other time basis like week, month, etc. This method is fast as it uses Pandas idioms instead of for loops.
There is only one streak in the example shown above, however, this method is robust to examples having mutiple streaks.
Hope this trick helps your data mining!