机器学习笔记(4)---K-近邻算法(2)---使用sklearn中的KNN算法

前言

上一篇文章《K-近邻算法(1)—约会对象魅力程度分类》中进行距离计算时使用的函数是由自己实现的classify0()完成,本篇文章改用sklearn库的KNN相关的接口实现。其实只要学会了上一节中的K-近邻算法,在其基础上只要做如下修改即可。最主要的修改就是调用分类函数的地方改成调用sklearn的库,然后在预测时注意下其返回的结果是个ndarray,取值方式稍有不同,其它都一样的。
转载请注明出处:http://blog.csdn.net/rosetta

Scikit learn 简介

也简称 sklearn, 是机器学习领域当中最知名的 python 模块之一。Sklearn 包含了很多种机器学习的方式:

  • Classification 分类
  • Regression 回归
  • Clustering 非监督分类
  • Dimensionality reduction 数据降维
  • Preprocessing 数据预处理

源码实现

from sklearn.neighbors import KNeighborsClassifier
def sklearn_classifyPerson():
    resultList = ['没有魅力', '魅力一般', '极具魅力']
    ffMiles = float(input("每年飞行公里数?"))
    percentTats=float(input("打游戏耗费时间的百分比?"))
    iceCream = float(input("每周消费的冰激凌?"))

    datingDataMat, datingLabels = file2matrix('datingTestSet2.txt')
    normMat, ranges, minVals = autoNorm(datingDataMat)
    inArr = np.array([ffMiles,percentTats,iceCream])
    # classifierResult = classify0((inArr-minVals)/ranges, normMat, datingLabels, 3)
    neigh = KNeighborsClassifier(n_neighbors=3)
    neigh.fit(normMat, datingLabels)

    classifierResult = neigh.predict([(inArr-minVals)/ranges])[0]#其返回的是ndarray,后面加[0]表示取里面的值。

    print("这个人:", resultList[classifierResult-1])

直接在Python的main函数中调用sklearn_classifyPerson函数即可。
运行结果如下:
使用sklearn KNN算法运行结果

如有疑问之处欢迎加我微信交流,共同进步!请备注“CSDN博客”
这里写图片描述

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值