- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的模型已保存,我正在尝试部署模型,但收到错误消息 AttributeError:“super”对象没有属性“get_params”。我无法在我的代码中找到任何错误。任何人都可以帮助解决这个问题。在此先感谢您的帮助。我的完整代码如下所示。
from flask import Flask, render_template, request
from datetime import date
import numpy as np
import pandas as pd
from dateutil.relativedelta import relativedelta
import pickle
app=Flask(__name__)
model=pickle.load(open('XGBoost.pkl','rb'))
@app.route('/',methods=['GET'])
def home():
return render_template('index.html')
@app.route('/predict',methods=['POST'])
def predict():
if request.method=='POST':
loan_amt=float(request.form['loan_amt'])
term=int(request.form['term'])
issue_d=str(request.form['issue_d'])
tol_paymnt=float(request.form['tol_paymnt'])
int_recvd=float(request.form['int_recvd'])
late_recv_fee=float(request.form['total_rec_late_fee'])
rcvry=float(request.form['rcvry'])
lst_pymnt_d=str(request.form['lst_pymnt_d'])
last_pymnt_amnt=float(request.form['last_pymnt_amnt'])
last_credit_pull_d=str(request.form['last_credit_pull_d'])
nxt_pymnt_d=str(request.form['nxt_pymnt_d'])
df=pd.DataFrame([[loan_amt,term,issue_d,tol_paymnt,int_recvd,late_recv_fee,rcvry,lst_pymnt_d,last_pymnt_amnt,last_credit_pull_d,nxt_pymnt_d]],
columns=('loan_amnt','term','issue_d','total_pymnt','total_rec_int','late_recv_fee','recoveries','last_pymnt_d','last_pymnt_amnt','last_credit_pull_d','nxt_pymnt_d'))
df['issue_d']=pd.to_datetime(df['issue_d']).dt.date
df['last_pymnt_d']=pd.to_datetime(df['last_pymnt_d']).dt.date
df['last_credit_pull_d']=pd.to_datetime(df['last_credit_pull_d']).dt.date
df['nxt_pymnt_d']=pd.to_datetime(df['nxt_pymnt_d']).dt.date
df['issue_d']=round((date.today()-df['issue_d'])/np.timedelta64(1,'M'))
df['last_pymnt_d']=round((date.today()-df['last_pymnt_d'])/np.timedelta64(1,'M'))
df['last_credit_pull_d']=round((date.today()-df['last_credit_pull_d'])/np.timedelta64(1,'M'))
df['nxt_pymnt_d']=round((date.today()-df['nxt_pymnt_d'])/np.timedelta64(1,'M'))
df['lst_nxt_pymnt_diff']=df['last_pymnt_d']-df['nxt_pymnt_d']
df['issue_lst_pymnt_diff']=df['issue_d']-df['nxt_pymnt_d']
df.drop(['nxt_pymnt_d'],axis=1,inplace=True)
input=np.asarray([[df['loan_amnt'],df['term'],df['issue_d'],df['total_pymnt'],df['total_rec_int'],df['late_recv_fee'],df['recoveries'],df['last_pymnt_d'],df['last_pymnt_amnt'],
df['last_credit_pull_d'],df['lst_nxt_pymnt_diff'],df['issue_lst_pymnt_diff']]])
prediction=model.predict(input)
if prediction==0:
return render_template('index.html',prediction_texts='Borrower will repay the loan amount.')
else:
return render_template('index.html',prediction_texts='Borrower will fail to repay the loan amount.')
else:
return render_template('index.html')
if __name__=='main':
app.run(debug=True)
错误的完整回溯如下所示。
Traceback (most recent call last):
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\werkzeug\serving.py", line 319, in run_wsgi xecute(self.server.app)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\werkzeug\serving.py", line 308, in execute application_iter = app(environ, start_response)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 2088, in __call__
return self.wsgi_app(environ, start_response)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 2073, in wsgi_app
response = self.handle_exception(e)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 2070, in wsgi_app
response = self.full_dispatch_request()
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 1515, in full_dispatch_request
rv = self.handle_user_exception(e)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 1513, in full_dispatch_request
rv = self.dispatch_request()
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\flask\app.py", line 1499, in dispatch_request
return self.ensure_sync(self.view_functions[rule.endpoint])(**req.view_args)
File "D:\Study material\Datasets\Python Project - Bank Lending\app.py", line 50, in predict
prediction=model.predict(input)
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\xgboost\sklearn.py", line 1209, in predict
class_probs = super().predict(
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\xgboost\sklearn.py", line 818, in predict
if self._can_use_inplace_predict():
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\xgboost\sklearn.py", line 758, in _can_use_inplace_predict
params = self.get_params()
File "C:\Users\Vikes\anaconda3\envs\loan_default\Lib\site-packages\xgboost\sklearn.py", line 438, in get_params
params = super().get_params(deep)
AttributeError: 'super' object has no attribute 'get_params'
您可以找到完整的代码 https://github.com/Vikeshkr-DSP/Loan_Default_Prediction
最佳答案
尝试将 scikit-learn 添加到您的 requirements.txt
关于python - 属性错误 : 'super' object has no attribute 'get_params' while deploying,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/68433215/
问题比较Java,但是我想在Android中实现: 假设有 3 个或更多类相互扩展: class A { ... int color; ... } class B extend
我知道标题听起来有点奇怪,但这正是我愿意做的。简单解释:A类是B类的子类,B类也是C类的子类>. 现在,所有这些类都包含方法m()。在我的 A 类中,这是我唯一可以访问的类,因为其他类仅在运行时可用,
我有一个 UIViewController 类 A 和 B。 A 使用以下方式加载 B:[A.view addSubView B.view]。 B 有一个带有“后退”按钮的导航栏。我想在单击时返回到
我有以下(第三方)类结构。我们将调用第三方项目 ProjectSeriously,并注意我使用 System.out.println 代替其他复杂的功能(100 行代码) . class A {
在下面的代码中,我从 Game 扩展了 MyGame。我有两个问题: 我们是否需要为所有render()、dispose()、pause()调用super方法 和 resize(w,h)?很多人都没有
例如,假设我想在调用 super.viewDidLoad() 时跳过一级。所以我希望能够做这样的事情: override func viewDidLoad() { super.super.vi
public class Faculty extends Employee { public static void main(String[] args) { new Fac
假设我有: class Superclass { //fields... methodA() {...} methodB() {...} ... } class Subclass exte
这个问题在这里已经有了答案: Why is super.super.method(); not allowed in Java? (22 个答案) 关闭 9 年前。 我怀疑我想做的事情是否可行。我有
我有一个实现 Initializable 的类。 public abstract class ExampleClass implements Initializable { public vo
我想知道,我有这个大数组,是否可以只在内存中使用一次而不是每个线程一次?以 stackoverflow 上的标签为例。他们几乎从不改变,为什么不为他们留下一个内存点呢?甚至可能将该数组永久保存在内存中
假设这三个类具有这个简单的层次结构: class A { func foo() { print("A") } } class B: A { override fu
有没有办法在 TypeScript 中调用 super.super.methodName。我想避免调用super.methodName,但我想调用二祖的methodName方法。 谢谢。 最佳答案 T
这个问题已经有答案了: When do I use super()? (11 个回答) 已关闭 7 年前。 package Geometry; public abstract class Geomet
我必须执行and()在我的实现 Predicate 的业务对象上. 出现问题的代码是 and() 行调用: Predicate predicate = new M
我有一个实现接口(interface)的抽象父类(super class): public abstract class FooMatrix implements Matrix { publi
我有四个 UIView:viewA 是 Root View ,它有 viewB 作为它的 subview 。 viewB 将 viewC 作为其 subview ,而 viewC 将 viewD 作为
有什么区别: class Child(SomeBaseClass): def __init__(self): super(Child, self).__init__() 和:
我有一个通用接口(interface) interface ListList extends List> .由于某些原因,我无法转换 ListList至 List> .有什么方法可以做到吗?为什么它不
我想调用带有两个参数的父类(super class)的构造函数,所以我调用了 super(arguments),但是编译器说: “类 Person 中的构造函数 Person 不能应用于给定类型; 要
我是一名优秀的程序员,十分优秀!