K近邻改进约会网站(二):数据图形化展示

本文介绍如何使用Python的matplotlib库绘制带有图例的散点图,并通过不同颜色和大小来区分数据类别。

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

简单绘制散点图的方法(无法添加图例):

from numpy import *
import kNN
import matplotlib.pyplot as plt


datingDataMat, datingLabels = kNN.file2matrix('datingTestSet2.txt')

fig = plt.figure()
ax = fig.add_subplot(111)
ax.scatter(datingDataMat[:, 1], datingDataMat[:, 2], 15.0 * array(datingLabels), 15.0 * array(datingLabels))
#以第二列特征和第三列特征绘制散点图,括号内的内容依次为x,y,大小s,颜色,颜色用4种数字表示,随机产生4中不同颜色
plt.show()
标准绘图:

import matplotlib.pyplot as plt
import kNN

plt.rcParams['font.sans-serif']=['Simhei']   #解决字体,和坐标轴符号问题
plt.rcParams['axes.unicode_minus']=False

datingDataMat, datingLabels = kNN.file2matrix('datingTestSet2.txt')

plt.figure()
axes = plt.subplot(111)

type1_x = []      #定义3中类型
type1_y = []
type2_x = []
type2_y = []
type3_x = []
type3_y = []

for i in range(len(datingLabels)):        #每组数按标签划分类别
    if datingLabels[i] == 1:
        type1_x.append(datingDataMat[i][0])
        type1_y.append(datingDataMat[i][1])

    if datingLabels[i] == 2:
        type2_x.append(datingDataMat[i][0])
        type2_y.append(datingDataMat[i][1])

    if datingLabels[i] == 3:
        type3_x.append(datingDataMat[i][0])
        type3_y.append(datingDataMat[i][1])

type1 = axes.scatter(type1_x, type1_y, s=20, c='r')    #分别设置大小颜色等属性
type2 = axes.scatter(type2_x, type2_y, s=40, c='b')
type3 = axes.scatter(type3_x, type3_y, s=60, c='k')

plt.legend((type1, type2, type3), ('不喜欢', '魅力一般', '极具魅力'))   #添加图例
plt.show()




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值