2744557306 发表于 2024-3-31 16:38

无监督学习练习 对客户进行分组


[*]客户细分(K-均值聚类)
[*]数据集:使用任何公开的客户数据集,如零售数据。
[*]任务:根据购买行为对客户进行分组。
[*]挑战:尝试不同的聚类算法(如DBSCAN、层次聚类)和调整参数来找到最佳的客户分组。

使用KMeans进行客户细分from sklearn.cluster import KMeans
from sklearn.preprocessing import StandardScaler
import pandas as pd

# 加载客户数据集
# 假设df是一个Pandas DataFrame,包含了你感兴趣的特征
# df = pd.read_csv('your_customer_data.csv')

# 对数据进行标准化处理
scaler = StandardScaler()
scaled_features = scaler.fit_transform(df)

# 使用KMeans进行聚类
kmeans = KMeans(n_clusters=5, random_state=42)
kmeans.fit(scaled_features)

# 将聚类结果添加到原始DataFrame中
df['Cluster'] = kmeans.labels_

# 查看聚类结果
print(df.head())在这个示例中,我们首先对特征进行了标准化处理,这是聚类分析中的一个常见步骤,以确保所有特征在相同的尺度上。然后,我们使用KMeans算法对客户进行了分组,这里假设我们想要将客户分成5个群体。尝试其他聚类算法DBSCANfrom sklearn.cluster import DBSCAN

# 使用DBSCAN进行聚类
dbscan = DBSCAN(eps=0.5, min_samples=5)
df['Cluster'] = dbscan.fit_predict(scaled_features)

# 查看聚类结果
print(df.head())层次聚类from sklearn.cluster import AgglomerativeClustering

# 使用层次聚类进行聚类
agg_clustering = AgglomerativeClustering(n_clusters=5, affinity='euclidean', linkage='ward')
df['Cluster'] = agg_clustering.fit_predict(scaled_features)

# 查看聚类结果
print(df.head())调整参数和选择算法
KMeans:n_clusters是一个关键参数,决定了聚类的数量。可以使用轮廓分析或肘方法来帮助确定最佳的聚类数量。
DBSCAN:eps和min_samples是关键参数,分别决定了样本成为核心点的条件。这些参数对结果的影响较大,通常需要通过尝试不同的值来找到最佳的参数设置。
层次聚类:n_clusters、affinity和linkage是重要的参数,它们分别控制聚类的数量、用于计算距离的方法和聚类合并的准则。
选择哪种聚类算法以及相应的参数设置,取决于数据集的特性和分析任务的目标。实践中,通常建议尝试多种聚类算法和参数配置,然后根据聚类的质量(例如,通过轮廓系数评估)来选择最佳的方法



页: [1]
查看完整版本: 无监督学习练习 对客户进行分组