python - sklearn 多线性回归-> dtype 错误
问题描述
我正在尝试使用线性回归模型来预测一个值。但是,当我使用 sklearn 中的 .predict 时,我找不到一种方法来插入 X 的数据而不会出现数据类型错误。
from sklearn import linear_model
KitchenQual_X = KitchenQual_df[["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea"]]
KitchenQual_Y = KitchenQual_df["dummy_KitchenQual"]
regr_KitchenQual = linear_model.LinearRegression()
regr_KitchenQual.fit(KitchenQual_X, KitchenQual_Y)
print("Predicted missing KitchenQual value: " + regr_KitchenQual.predict(df_both[["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea"]].loc[[1555]]))
在我的 kaggle 笔记本中运行代码时,我收到以下错误:
---------------------------------------------------------------------------
UFuncTypeError Traceback (most recent call last)
<ipython-input-206-1f022a48e21c> in <module>
----> 1 print("Predicted missing KitchenQual value: " + regr_KitchenQual.predict(df_both[["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea"]].loc[[1555]]))
UFuncTypeError: ufunc 'add' did not contain a loop with signature matching types (dtype('<U37'), dtype('<U37')) -> dtype('<U37')
我将不胜感激任何帮助 :)
解决方案
假设您的因变量是连续的,使用示例数据并重复您的步骤:
from sklearn import linear_model
import numpy as np
import pandas as pd
KitchenQual_df = pd.DataFrame(np.random.normal(0,1,(2000,6)))
KitchenQual_df.columns = ["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea","dummy_KitchenQual"]
KitchenQual_X = KitchenQual_df[["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea"]]
KitchenQual_Y = KitchenQual_df["dummy_KitchenQual"]
regr_KitchenQual = linear_model.LinearRegression()
regr_KitchenQual.fit(KitchenQual_X, KitchenQual_Y)
pred = regr_KitchenQual.predict(KitchenQual_df[["OverallQual", "YearBuilt", "YearRemodAdd", "GarageCars", "GarageArea"]].loc[[1555]])
预测是一个数组,你不能只使用 连接一个字符串和一个数组+
,下面的这些负面例子在问题中给你同样的错误:
"a" + np.array(['b','c'])
"a" + np.array([1,2])
UFuncTypeError: ufunc 'add' did not contain a loop with signature matching types (dtype('<U1'), dtype('<U1')) -> dtype('<U1')
你可以做:
print("Predicted missing KitchenQual value: " + str(pred[0]))
Predicted missing KitchenQual value: -0.11176904834490986
推荐阅读
- matlab - 在 MATLAB 上使用 Alexnet/Googlenet 等进行图像分割
- structuremap - 使用 StructureMap 在对象层次结构之间共享数据
- azure - 我想使用 Powershell 将我的 Web 应用程序的特定文件和文件夹备份到 Blob 存储
- android - 我可以使用智能手机生物识别传感器扫描公共指纹吗
- c++ - C++ - 在 Windows 上是否有任何命令喜欢 addr2line
- php - 使用 JQuery 在 fullcalendar 中保存事件不起作用
- sql - 在 SQL Developer 3.1.07 中为用户输入提供消息提示
- java - 如何从 Java 7 调用 Kotlin 挂起协程函数
- objective-c - 使用 SwiftyJSON 导出的 Swift 框架面临:由于未捕获的异常而终止应用程序
- c - 打印随机数而不是我的 var