use*_*459 19 python-3.x pandas scikit-learn
我试图用高斯朴素贝叶斯"分类器"来预测经济周期.
数据(输入X):
SPY Interest Rate Unemployment Employment CPI
Date
1997-01-02 56.05 7.82 9.7 3399.9 159.100
1997-02-03 56.58 7.65 9.8 3402.8 159.600
1997-03-03 54.09 7.90 9.9 3414.7 160.000
Run Code Online (Sandbox Code Playgroud)
目标(输出Y):
Economy
0 Expansion
1 Expansion
2 Expansion
3 Expansion
Run Code Online (Sandbox Code Playgroud)
以下是我的代码:
from sklearn.naive_bayes import GaussianNB
from sklearn import metrics
from sklearn.cross_validation import train_test_split
X = data
Y = target
model = GaussianNB
X_train, X_test, Y_train, Y_test = train_test_split(X,Y)
model.fit(X_train, Y_train)
Run Code Online (Sandbox Code Playgroud)
以下是错误:
TypeError Traceback (most recent call last)
<ipython-input-132-b0975752a19f> in <module>()
6 model = GaussianNB
7 X_train, X_test, Y_train, Y_test = train_test_split(X,Y)
----> 8 model.fit(X_train, Y_train)
TypeError: fit() missing 1 required positional argument: 'y'
Run Code Online (Sandbox Code Playgroud)
我究竟做错了什么?我该如何解决此问题/错误?
小智 10
每当您尝试初始化/定义类的对象时,您必须调用它自己的构造函数来为您创建一个对象。构造函数可能有参数,也可能没有。在您的情况下, GaussianNB是来自 sklearn 的类,默认情况下具有非参数构造函数。
obj_model = GaussianNB()
Run Code Online (Sandbox Code Playgroud)
因此,我们确实创建了一个带有空括号的对象,这仅表示默认构造函数。
以防万一其他人遇到这个问题,遭受与我相同的根本原因:当您尝试将方法“fit”作为类上的静态方法(类方法)调用而不是调用它时,也会发生此错误类的实例化对象。这也适用于其他框架中的其他分类器,例如 PySpark。
例如,这不起作用:
model = LogisticRegression.fit(data)
Run Code Online (Sandbox Code Playgroud)
但这会:
log_reg = LogisticRegression()
model = log_reg.fit(data)
Run Code Online (Sandbox Code Playgroud)
小智 5
你忘了把()你的模型放在后面,gaussianNB. 尝试在第 6 行执行此操作:
model = GaussianNB()
Run Code Online (Sandbox Code Playgroud)
我很确定它会解决问题。
| 归档时间: |
|
| 查看次数: |
50858 次 |
| 最近记录: |