Python机器学习:KNN算法03训练数据集,测试数据集train test split

示例代码
首先引入相关包

import numpy as np
import matplotlib.pyplot as plt
from sklearn import datasets
import pandas as pd

下载鸢尾花数据集

iris = datasets.load_iris()
print(type(iris))
<class 'sklearn.utils.Bunch'>

数据和数据类别

X = iris.data
y = iris.target
print(X.shape)
print(y.shape)

在这里插入图片描述
train_test_split

#train_test_split
#y是排好序的,前50个是0,中间50个是1,后面50个是2
#将原始数据打乱随机化,X,y分离..他们之间有对应关系
#第一种方式把X,y合并然后打乱,然后拆分(有时间试验试一下)
#我们使用第二种
#随机索引
shuffle_index = np.random.permutation(len(X))
print(shuffle_index)

输出结果

[ 30  22  56  92  55   2  85 118   5  60  36  33  81  75  83 117  12  80
 128  19 105  42  98  69  68  35  20   0  88  38  65 149  58 119  45  48
 109  43 113  79 114  29  74  90  11  91 124  57 148 130  63 129 139  17
  32  93  40   7 146  21 136   8  16 127 140  62  13  14  59 121   4  54
  49  41 132  67 110  64  78 137  24  97 122  47 108   1  28  61  82  86
 111 116  87  72 101  
  • 2
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 下面是一个使用 Python 编写的 KNN 算法分类 Wine 数据集的示例代码: ```python import numpy as np import pandas as pd import matplotlib.pyplot as plt from sklearn.model_selection import train_test_split from sklearn.neighbors import KNeighborsClassifier from sklearn import datasets # 加载 Wine 数据集 wine = datasets.load_wine() # 将数据转换为 DataFrame 格式 df = pd.DataFrame(data=np.c_[wine['data'], wine['target']], columns=wine['feature_names'] + ['target']) # 划分数据集 X_train, X_test, y_train, y_test = train_test_split(df.iloc[:, :-1], df.iloc[:, -1], test_size=0.2) # 训练 KNN 分类器 knn = KNeighborsClassifier(n_neighbors=5) knn.fit(X_train, y_train) # 计算准确率 accuracy = knn.score(X_test, y_test) print("Accuracy:", accuracy) # 将数据可视化 colors = ['red', 'green', 'blue'] for target, color in zip(np.unique(wine['target']), colors): indices = np.where(df['target'] == target) plt.scatter(df.iloc[indices, 0], df.iloc[indices, 1], c=color, s=50, alpha=0.7) plt.show() ``` 运行上面的代码,将会先对 Wine 数据集进行 KNN 分类,最后使用 Matplotlib 库绘制出分类结果的散点图,以图形化地表示 Wine 数据集的分类情况。 ### 回答2: K最近邻(K-Nearest Neighbors,KNN)算法是一种常用的分类算法,可以用于对数据集进行分类。在这里,我们使用Python编程来实现使用KNN算法对wine数据集进行分类,并用图形化展示结果。 首先,我们需要导入必要的库。我们使用sklearn库中的load_wine功能加载wine数据集,以及train_test_split函数分割数据集训练集测试集。我们还使用matplotlib库中的pyplot模块绘制图形化结果。 以下是代码示例: ```python import matplotlib.pyplot as plt from sklearn.datasets import load_wine from sklearn.model_selection import train_test_split from sklearn.neighbors import KNeighborsClassifier # 加载wine数据集 wine = load_wine() X = wine.data y = wine.target # 将数据集分割为训练集测试集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3) # 使用KNN算法进行分类 knn = KNeighborsClassifier() knn.fit(X_train, y_train) y_pred = knn.predict(X_test) # 绘制图形化结果 plt.scatter(X_test[:, 0], X_test[:, 1], c=y_pred) plt.xlabel('Feature 1') plt.ylabel('Feature 2') plt.title('Wine Dataset Classification') plt.show() ``` 以上代码首先导入了所需的库。然后使用load_wine函数加载wine数据集,并将特征数据赋值给X变量,标签数据赋值给y变量。 接下来,我们使用train_test_split函数数据集分割为训练集测试集,其中测试集占总数据集的30%。 然后,我们使用KNN算法训练集进行训练,并使用测试集进行预测。预测结果赋值给y_pred变量。 最后,我们使用scatter函数绘制散点图,其中X轴和Y轴分别表示wine数据集的第一个和第二个特征,分类结果用不同颜色表示。同时,我们还设置了轴标签和图像标题。 在运行代码后,会显示图形化结果,用不同颜色的散点表示不同的分类。这样,我们用Python编程实现了使用KNN算法对wine数据集进行分类,并用图形化表示结果。 ### 回答3: K近邻算法(K-Nearest Neighbors,KNN)是一种基本而常用的机器学习算法,用于分类和回归问题。在这里,我们将使用 Python 编程来实现 KNN 算法并对 Wine 数据集进行分类,并使用图形化来展示分类结果。 首先,我们需要导入必要的 Python 库,包括 pandas、numpy 和 matplotlib。然后,我们将加载 Wine 数据集,该数据集包含有关不同葡萄酒的化学分析结果。 接下来,我们将对数据集进行预处理。我们将数据集中的特征数据存储在 X 中,并将数据集中的标签数据存储在 y 中。然后,我们将数据集划分为训练集测试集,通常将数据集的 70% 用于训练,30% 用于测试。 接下来,我们将使用 sklearn 库中的 KNeighborsClassifier 类来创建 KNN 分类器。我们可以指定 K 值(即最近的 K 个邻居),这是 KNN 算法的一个重要参数。 然后,我们将使用训练集拟合 KNN 分类器,并使用测试集进行预测。最后,我们将使用图形化工具(如 matplotlib)将测试集中的真实标签和预测标签进行可视化。 下面是一个简单的实现示例: ```python import pandas as pd import numpy as np import matplotlib.pyplot as plt from sklearn.model_selection import train_test_split from sklearn.neighbors import KNeighborsClassifier # 加载数据集 data = pd.read_csv('wine.csv') X = data.drop('Class', axis=1) y = data['Class'] # 数据集划分为训练集测试集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.3) # 创建KNN分类器 knn = KNeighborsClassifier(n_neighbors=3) # 拟合KNN分类器 knn.fit(X_train, y_train) # 使用测试集进行预测 y_pred = knn.predict(X_test) # 可视化分类结果 plt.scatter(X_test['Alcohol'], X_test['Malic acid'], c=y_test) plt.scatter(X_test['Alcohol'], X_test['Malic acid'], c=y_pred, marker='x') plt.xlabel('Alcohol') plt.ylabel('Malic acid') plt.title('KNN Classification') plt.show() ``` 上面的代码是一个简单的 KNN 分类算法实现和可视化示例,其中 wine.csv 是包含有关葡萄酒化学分析结果的 CSV 文件。该代码数据集划分为训练集测试集,使用训练集拟合 KNN 分类器,并使用测试集进行预测。最后,使用 matplotlib 图形化工具将测试集中的真实标签和预测标签进行可视化。 这样,我们就实现了 KNN 算法对 Wine 数据集进行分类,并用图形化表示。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值