这是由于默认值的更改配置设置 https://scikit-learn.org/stable/modules/generated/sklearn.set_config.html#sklearn.set_config从 scikit-learn v0.23 开始;来自变更日志 https://scikit-learn.org/stable/whats_new/v0.23.html#id13:
默认设置print_changed_only
已从 False 更改为 True。这意味着repr
估计器现在更加简洁,仅显示在打印估计器时默认值已更改的参数。您可以使用以下命令恢复以前的行为sklearn.set_config(print_changed_only=False)
。另请注意,始终可以使用以下命令快速检查任何估计器的参数est.get_params(deep=False)
.
也就是说,在v0.23之前的版本中,如下代码:
import sklearn
sklearn.__version__
# 0.22.2
from sklearn.linear_model import LogisticRegression
lr = LogisticRegression()
lr
使用所有模型参数生成以下输出:
LogisticRegression(C=1.0, class_weight=None, dual=False, fit_intercept=True,
intercept_scaling=1, l1_ratio=None, max_iter=100,
multi_class='auto', n_jobs=None, penalty='l2',
random_state=None, solver='lbfgs', tol=0.0001, verbose=0,
warm_start=False)
但从 v0.23 开始,代码相同:
import sklearn
sklearn.__version__
# 0.23.2
from sklearn.linear_model import LogisticRegression
lr = LogisticRegression()
lr
将产生:
LogisticRegression()
在像这里这样的情况下,即没有明确定义参数,并且所有参数都保留默认值。那是因为print_changed_only
参数现在默认设置为True
:
sklearn.get_config()
# result:
{'assume_finite': False,
'working_memory': 1024,
'print_changed_only': True,
'display': 'text'}
要获取较新的 scikit-learn 版本中打印的所有参数,您应该执行以下操作
lr.get_params()
# result
{'C': 1.0,
'class_weight': None,
'dual': False,
'fit_intercept': True,
'intercept_scaling': 1,
'l1_ratio': None,
'max_iter': 100,
'multi_class': 'auto',
'n_jobs': None,
'penalty': 'l2',
'random_state': None,
'solver': 'lbfgs',
'tol': 0.0001,
'verbose': 0,
'warm_start': False}
或更改设置(最好,因为它会影响之后使用的所有模型):
sklearn.set_config(print_changed_only=False) # needed only once
lr # as defined above
# result
LogisticRegression(C=1.0, class_weight=None, dual=False, fit_intercept=True,
intercept_scaling=1, l1_ratio=None, max_iter=100,
multi_class='auto', n_jobs=None, penalty='l2',
random_state=None, solver='lbfgs', tol=0.0001, verbose=0,
warm_start=False)