import pandas as pd import numpy as np from sklearn.preprocessing import MinMaxScaler from sklearn.model_selection import train_test_split from keras.models import Sequential from keras.layers import Dense # 读取Excel文件 data = pd.read_excel('D://数据3.xlsx', sheet_name='5') # 把数据分成输入和输出 X = data.iloc[:, 0:5].values y = data.iloc[:, 0:5].values # 对输入和输出数据进行归一化 scaler_X = MinMaxScaler(feature_range=(0, 5)) X = scaler_X.fit_transform(X) scaler_y = MinMaxScaler(feature_range=(0, 5)) y = scaler_y.fit_transform(y) # 将数据集分成训练集和测试集 X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2, random_state=0) # 创建神经网络模型 model = Sequential() model.add(Dense(units=5, input_dim=5, activation='relu')) model.add(Dense(units=12, activation='relu')) model.add(Dense(units=5, activation='relu')) model.add(Dense(units=5, activation='linear')) # 编译模型 model.compile(loss='mean_squared_error', optimizer='sgd') # 训练模型 model.fit(X_train, y_train, epochs=300, batch_size=500) # 评估模型 score = model.evaluate(X_test, y_test, batch_size=1500) # 使用训练好的模型进行预测 X_test_scaled = scaler_X.transform(X_test) y_pred = model.predict(X_test_scaled) # 对预测结果进行反归一化 y_pred_int = scaler_y.inverse_transform(y_pred).round().astype(int) # 构建带有概率的预测结果 y_pred_prob = pd.DataFrame(y_pred_int, columns=data.columns[:5]) mse = ((y_test - y_pred) ** 2).mean(axis=None) y_pred_prob['Probability'] = 1 / (1 + mse - ((y_pred_int - y_test) ** 2).mean(axis=None)) # 过滤掉和值超过5或小于5的预测值 row_sums = np.sum(y_pred, axis=1) y_pred_filtered = y_pred[(row_sums >= 5) & (row_sums <= 5), :] # 去除重复的行 y_pred_filtered = y_pred_filtered.drop_duplicates() # 重新计算低于1.2的 Probability 值 low_prob_indices = y_pred_filtered[y_pred_filtered['Probability'] < 1.5].index for i in low_prob_indices: y_pred_int_i = y_pred_int[i] y_test_i = y_test[i] mse_i = ((y_test_i - y_pred_int_i) ** 2).mean(axis=None) new_prob_i = 1 / (1 + mse_i - ((y_pred_int_i - y_test_i) ** 2).mean(axis=None)) y_pred_filtered.at[i, 'Probability'] = new_prob_i # 打印带有概率的预测结果 print('Predicted values with probabilities:') print(y_pred_filtered) # 保存模型 model.save('D://大乐透5.h5')程序中显示Python 的错误提示,提示中提到了一个 'numpy.ndarray' 对象没有 'drop_duplicates' 属性。这可能是因为你将一个 numpy 数组传递给了 pandas 的 DataFrame.drop_duplicates() 方法,而这个方法只能用于 pandas 的 DataFrame 类型数据。你可以尝试将 numpy 数组转换为 pandas 的 DataFrame 对象,然后再进行去重操作这个怎么改
时间: 2024-02-12 21:07:30 浏览: 379
pandas.read_csv参数详解(小结)
你需要将 `y_pred_filtered` 从 numpy 数组转换成 pandas 的 DataFrame 对象,然后再进行去重操作。可以使用 `pd.DataFrame()` 将 `y_pred_filtered` 转换成 DataFrame 对象,然后再使用 `drop_duplicates()` 方法去重。修改代码如下所示:
```
# 过滤掉和值超过5或小于5的预测值
row_sums = np.sum(y_pred, axis=1)
y_pred_filtered = y_pred[(row_sums >= 5) & (row_sums <= 5), :]
# 转换为 DataFrame 对象
y_pred_filtered = pd.DataFrame(y_pred_filtered, columns=data.columns[:5])
# 去除重复的行
y_pred_filtered = y_pred_filtered.drop_duplicates()
```
这样就可以将 `y_pred_filtered` 转换为 DataFrame 对象并进行去重操作。
阅读全文