簡體   English   中英

AttributeError:“ numpy.ndarray”對象沒有屬性“ values”

[英]AttributeError: 'numpy.ndarray' object has no attribute 'values'

我正在嘗試建立一個簡單的神經網絡,您可以在下面找到我的代碼。 當我運行它時,我收到一條錯誤消息:

Traceback (most recent call last):
  File "algosofleetNNkuantic2.py", line 41, in <module>
    mlp.fit(X_train, y_train.values.ravel())
AttributeError: 'numpy.ndarray' object has no attribute 'values'

你能告訴我我做錯了什么,我需要做些什么來解決? 提前致謝。

完整代碼:

import pandas as pd
from sklearn import preprocessing
from sklearn.model_selection import train_test_split
from sklearn.neural_network import MLPClassifier
from sklearn.metrics import classification_report, confusion_matrix 
import csv
from sklearn.preprocessing import LabelEncoder


path = "C:\\Users\\YannickLECROART\\Desktop\\modeleimportMD.csv"
file = open(path, newline='')
reader = csv.reader(file)
#commandes pour ouvrir et lire un fichier CSV en tant que modele pour le classifieur

header = next(reader) #la 1ere ligne correspond au titre
modele_X = []
modele_Y =  []
#on crée 2 variables que l'on va remplir des données des colonnes du fichier CSV importé pour le modèle
for row in reader: #on va associer les données des colonnes à des variables

    param1  = float(row[0])
    param2 =  float(row[1])
    param3 = float(row[2])
    param4 = float(row[3])
    param5 = float(row[4])
    param6 = float(row[5])
    resultat = str(row[6])
    modele_X.append([param1,param2,param3,param4,param5,param6]) #on associe ensuite toutes les données collectées à la variable créée plus haut sans tenir compte de la dernière colonne qui correspond au résultat 
    modele_Y.append(resultat) #on associe les données venant de la dernière colonne résultat à la variable créée plus haut et non utilisée pour les prédictions mais utiles pour l'export CSV


le = preprocessing.LabelEncoder()

enc = LabelEncoder().fit(modele_Y)
Y_encode = enc.transform(modele_Y)
 #print(Y_encode)

X_train, X_test, y_train, y_test = train_test_split(modele_X, Y_encode, test_size = 0.20)

mlp = MLPClassifier(hidden_layer_sizes=(10, 10, 10), max_iter=1000)  
mlp.fit(X_train, y_train.values.ravel())

predictions = mlp.predict(X_test)
print(predictions)

print(confusion_matrix(y_test,predictions))  
print(classification_report(y_test,predictions))

在線上

mlp.fit(X_train, y_train.values.ravel())

y_train的類型為numpy.ndarray ,並且顯示在錯誤消息中

沒有屬性“值”

如果您已經對該數組進行了正確的編碼,則應該可以將其簡單地用作

mlp.fit(X_train, y_train)

我有同樣的錯誤,但這可行

random_forest.fit(X_train,y_train.ravel())

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM