Klantsegmentatie in Python
Karolis Urbonas
Head of Data Science, Amazon
We hebben de preprocessing afgerond en deze twee objecten:
datamart_rfmdatamart_normalizedimport numpy as np
datamart_log = np.log(datamart_rfm)
from sklearn.preprocessing import StandardScaler
scaler = StandardScaler()
scaler.fit(datamart_log)
datamart_normalized = scaler.transform(datamart_log)
# Import package
from sklearn.cluster import KMeans
kmeans = KMeans(n_clusters=2, random_state=1)
# K-means op geprepte data uitvoeren
kmeans.fit(datamart_normalized)
# Clusterlabels ophalen uit het attribuut labels_
cluster_labels = kmeans.labels_
# Maak een clusterlabelkolom in de originele DataFrame
datamart_rfm_k2 = datamart_rfm.assign(Cluster = cluster_labels)
# Bereken gemiddelde RFM-waarden en grootte per cluster
datamart_rfm_k2.groupby(['Cluster']).agg({
'Recency': 'mean',
'Frequency': 'mean',
'MonetaryValue': ['mean', 'count'],
}).round(0)
Het resultaat van een simpele 2-clusteroplossing:
Klantsegmentatie in Python