K-means聚类分析,并用t-SNE可视化聚类结果

本文介绍如何使用K-means算法对客户消费行为数据进行聚类分析,并运用t-SNE技术进行数据降维及可视化。通过具体实例展示了从数据预处理到最终聚类结果呈现的完整流程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

K-means聚类分析,并用t-SNE可视化聚类结果

k-means算法,即k-均值聚类,也叫快速聚类算法,在最小化误差函数的基础上将数据划分为预定的类数k。
t-SNE属于非线性降维,具体需要研究算法原理的博友可以参考http://www.datakit.cn/blog/2017/02/05/t_sne_full.html和https://blog.youkuaiyun.com/hustqb/article/details/78144384两篇博文。

具体实例
数据如下
在这里插入图片描述
此为客户消费行为特征数据,R表示最近一次消费时间间隔,F表示消费频率,M表示消费总金额。
需要通过聚类分析将不同消费群体分类出来
代码如下:

#k_mean算法
import pandas as pd

#参数初始化
inputfile = '../data/consumption_data.xls' #销量及其他属性数据
outputfile = '../tmp/data_type.xls' #保存结果的文件名
k = 3 #聚类的类别
iteration = 3 #聚类最大循环次数
data = pd.read_excel(inputfile, index_col = 'Id') #读取数据
data_zs = 1.0*(data - data.mean())/data.std() #数据标准化,std()表示求总体样本方差(除以n-1),numpy中std()是除以n
print(data_zs)

from sklearn.cluster import KMeans
model = KMeans(n_clusters = k, max_iter = iteration) #分为k类
#model = KMeans(n_clusters = k, n_jobs = 4, max_iter = iteration) #分为k类,并发数4
model.fit(data_zs) #开始聚类

#简单打印结果
r1 = pd.Series(model.labels_).value_counts() #统计各个类别的数目
r2 = pd.DataFrame(model.cluster_centers_) #找出聚类中心
r = pd.concat([r2, r1], axis = 1) #横向连接(0是纵向),得到聚类中心对应的类别下的数目
print(r)
r.columns = list(data.columns) + [u'类别数目'] #重命名表头
print(r)

#详细输出原始数据及其类别
r = pd.concat([data, pd.Series(model.labels_, index = data.index)], axis = 1)  #详细输出每个样本对应的类别
r.columns = list(data.columns) + [u'聚类类别'] #重命名表头
r.to_excel(outputfile) #保存结果
#用TSNE进行数据降维并展示聚类结果
from sklearn.manifold import TSNE
tsne = TSNE()
tsne.fit_transform(data_zs) #进行数据降维,并返回结果
tsne = pd.DataFrame(tsne.embedding_, index = data_zs.index) #转换数据格式

import matplotlib.pyplot as plt
plt.rcParams['font.sans-serif'] = ['SimHei'] #用来正常显示中文标签
plt.rcParams['axes.unicode_minus'] = False #用来正常显示负号

#不同类别用不同颜色和样式绘图
d = tsne[r[u'聚类类别'] == 0]     #找出聚类类别为0的数据对应的降维结果
plt.plot(d[0], d[1], 'r.')
d = tsne[r[u'聚类类别'] == 1]
plt.plot(d[0], d[1], 'go')
d = tsne[r[u'聚类类别'] == 2]
plt.plot(d[0], d[1], 'b*')
plt.show()

在这里插入图片描述

参考文献
[1]张良均等著《python数据分析与挖掘实战》

### T-SNE可视化方法及其Python实现 #### t-SNE简介 t-SNE(t-Distributed Stochastic Neighbor Embedding)是一种非线性的降维技术,专门设计用来捕捉高维数据中的局部结构并将其映射到低维空间中[^2]。这种方法尤其适用于那些具有复杂内部结构的数据集,在这些情况下,传统线性降维算法可能无法很好地保留原始特征。 #### 工作原理概述 该算法的核心在于转换概率分布:首先计算输入数据集中每一对点之间相似度的概率分布;接着在同一方式下构建目标低维表示的空间内的对应分布;最后调整后者使得两者尽可能接近。这种机制允许即使是非常不同的两类对象也能被区分开来,只要它们在原空间中有足够的差异即可。 #### Python实现示例 为了方便理解和应用这一强大的工具,下面给出了一段基于`scikit-learn`库的简单代码片段,展示了如何加载鸢尾花(Iris)数据集并通过调用`t-SNE`函数完成降维过程以及最终的结果绘图: ```python from sklearn import datasets from sklearn.manifold import TSNE import matplotlib.pyplot as plt # 加载Iris数据集 iris = datasets.load_iris() X, y = iris.data, iris.target # 使用TSNE进行降维 tsne = TSNE(n_components=2, random_state=0) X_tsne = tsne.fit_transform(X) # 绘制二维散点图 plt.figure(figsize=(8, 6)) for i in range(len(set(y))): mask = (y == i) plt.scatter(X_tsne[mask, 0], X_tsne[mask, 1], label=f'Class {i}') plt.legend() plt.show() ``` 上述代码不仅实现了基本的功能需求——即从四维降到两维以便于观察——而且还加入了不同类别间区分的颜色标记,从而更直观地展现了各类样本之间的关系[^3]。
评论 13
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值