我从Udemy那里学习KNN。数据集从这里下载。
当我尝试运行以下代码时:
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
dataset = pd.read_csv('Social_Network_Ads.csv')
x = dataset.iloc[:, [2, 3]].values
y = dataset.iloc[:, 4:].values
from sklearn.model_selection import train_test_split
x_train, x_test, y_train, y_test = train_test_split(x, y, test_size=0.25, random_state=0)
from sklearn.preprocessing import StandardScaler
sc = StandardScaler()
x_train = sc.fit_transform(x_train)
x_test = sc.transform(x_test)
from sklearn.neighbors import KNeighborsClassifier
classifier = KNeighborsClassifier(n_neighbors=5, metric='minkowski', p=2)
classifier.fit(x_train, y_train.ravel())
y_pred = classifier.predict(x_train)
from sklearn.metrics import confusion_matrix
cm = confusion_matrix(y_test, y_pred)
我得到的错误是:
回溯(最近一次调用):文件“/home/ashutosh/Machine Learning A-Z Template Folder/Part 3-分类/第15节-K-最近邻(K-NN)/knn(1.py)”,第24行,cm=混淆矩阵(y\u test,y\u pred)
文件“/home/ashutosh/.local/lib/python3.7/site packages/sklearn/metrics/\u classification.py”,第268行,混乱矩阵y类型,y真,y pred=\u检查目标(y真,y pred)
文件“/home/ashutosh/.local/lib/python3.7/site packages/sklearn/metrics/\u classification.py”,第80行,in\u check\u targets check\u constance\u length(y\u true,y\u pred)
文件“/home/ashutosh/.local/lib/python3.7/site packages/sklearn/utils/validation.py”,第212行,在检查一致长度“样本:%r”%[int(l)表示长度为l])
ValueError:找到样本数不一致的输入变量:[100300]
谢谢=)
可以通过Request对象完成全局输入变量的检测、获取和安全过滤,支持包括$_GET、$_POST、$_REQUEST、$_SERVER、$_SESSION、$_COOKIE、$_ENV等系统变量,以及文件上传信息。 获取PARAM变量 PARAM变量是 TP5推荐的获取请求参数的方式 // 获取当前请求的id变量 $request->param('id'); // 获取当前请求的所有变量(已过
请参考:http://www.kancloud.cn/manual/thinkphp/1721
可以通过Request对象完成全局输入变量的检测、获取和安全过滤,支持包括$_GET、$_POST、$_REQUEST、$_SERVER、$_SESSION、$_COOKIE、$_ENV等系统变量,以及文件上传信息。 获取PARAM变量 PARAM变量是 TP6.0推荐的获取请求参数的方式 // 获取当前请求的id变量 $request->param('id'); // 获取当前请求的所有变量(
可以通过Request对象完成全局输入变量的检测、获取和安全过滤,支持包括$_GET、$_POST、$_REQUEST、$_SERVER、$_SESSION、$_COOKIE、$_ENV等系统变量,以及文件上传信息。 为了方便说明,本篇内容的所有示例代码均使用Facade方式,因此需要首先引入 use think\facade\Request; 如果你使用的是依赖注入,请自行调整代码为动态调用即可