0

0

Python特征选择怎么做_过滤法方差分析/包装法/嵌入法树模型特征精准筛选

P粉602998670

P粉602998670

发布时间:2026-03-18 12:36:31

|

635人浏览过

|

来源于php中文网

原创

VarianceThreshold默认阈值为0,仅剔除方差为0的特征;需设非零threshold才过滤低方差特征,且输入须为数值型,稀疏矩阵需防转密。

python特征选择怎么做_过滤法方差分析/包装法/嵌入法树模型特征精准筛选

方差过滤 VarianceThreshold 为什么没筛掉低方差特征?

因为默认阈值是 0,只剔除完全不变的特征(方差为 0 的列)。实际数据里,很多特征方差极小但不为 0,比如某列 99% 是 0、1% 是 1,VarianceThreshold() 默认根本不会动它。

  • 必须显式设 threshold=0.01 这类非零值,才真正起过滤作用
  • 注意:输入必须是数值型,类别型字段(如 'high'/'low')会报错,得先用 OneHotEncoderLabelEncoder 转换
  • 对稀疏矩阵支持好,但若用 fit_transform 后再传给树模型,记得检查是否意外转成了密集数组——内存可能暴涨

SelectKBestf_classif 报错 ValueError: Input X must be non-negative

这是 f_classif(用于分类任务的 F 检验)的硬性要求:所有特征值必须 ≥ 0。不是数据有负数就一定错,而是它内部调用的 scipy 函数明确拒绝负值。

  • 常见场景:你用了标准化(StandardScaler),结果把特征中心化到均值为 0,自然出现负数
  • 解法不是“去掉标准化”,而是换评估器:mutual_info_classif 不限制正负,或改用 SelectPercentile + chi2(但后者仍要求非负,仅适用于计数类特征)
  • 注意 f_classiff_regression 名字像、用法像,但任务类型不能混——前者只接受整数/字符串标签,后者才吃浮点目标值

RFECV 包装法选特征,结果每次运行都不一样

核心原因是默认的 estimator(如 RandomForestClassifier)本身带随机性,且 RFECV 内部做交叉验证时也涉及数据打乱。

  • 固定随机种子:给 estimatorrandom_state=42,同时在 RFECV 里传 cv=StratifiedKFold(n_splits=5, shuffle=True, random_state=42)
  • 别省计算:默认 step=1 是逐个剔特征,慢但稳定;设成 step=0.1(按比例删)会跳过中间状态,路径不可复现
  • 小心过拟合信号:如果 CV 得分曲线在某个特征数后开始震荡上升,不是模型变强了,很可能是验证集太小或随机性干扰,建议加大 cv 折数

树模型 feature_importances_ 为啥和实际业务直觉冲突?

树模型(如 RandomForestXGBoost)输出的重要性,本质是基于分裂增益的统计量,不反映变量对目标的独立影响,更不等价于回归系数的符号或量级。

Jamboss
Jamboss

Jamboss是一款简单的AI音乐生成App,可以一键生成歌曲。

下载

立即学习Python免费学习笔记(深入)”;

  • 高度相关的特征会“争抢”重要性——比如 ageage_squared 同时存在,其中一个得分可能虚高,另一个被压低
  • XGBoost 默认用 gain,但也可切到 weight(分裂次数)或 cover(覆盖样本数),三者排序常不一致,得看你想解释什么
  • 单棵树的 feature_importances_ 噪声极大,务必用集成模型(≥ 100 棵树),且检查 std 是否远小于均值,否则这组重要性本身就不稳定

真实项目里,树的重要性只能当第一轮线索,真要确认某个特征是否该留,得结合部分依赖图(PartialDependenceDisplay)、SHAP 值,或者干脆做消融实验——删掉它,看线上指标掉多少。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

761

2023.08.03

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

221

2023.09.04

java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1571

2023.10.24

字符串介绍
字符串介绍

字符串是一种数据类型,它可以是任何文本,包括字母、数字、符号等。字符串可以由不同的字符组成,例如空格、标点符号、数字等。在编程中,字符串通常用引号括起来,如单引号、双引号或反引号。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

652

2023.11.24

java读取文件转成字符串的方法
java读取文件转成字符串的方法

Java8引入了新的文件I/O API,使用java.nio.file.Files类读取文件内容更加方便。对于较旧版本的Java,可以使用java.io.FileReader和java.io.BufferedReader来读取文件。在这些方法中,你需要将文件路径替换为你的实际文件路径,并且可能需要处理可能的IOException异常。想了解更多java的相关内容,可以阅读本专题下面的文章。

1269

2024.03.22

php中定义字符串的方式
php中定义字符串的方式

php中定义字符串的方式:单引号;双引号;heredoc语法等等。想了解更多字符串的相关内容,可以阅读本专题下面的文章。

1226

2024.04.29

go语言字符串相关教程
go语言字符串相关教程

本专题整合了go语言字符串相关教程,阅读专题下面的文章了解更多详细内容。

194

2025.07.29

c++字符串相关教程
c++字符串相关教程

本专题整合了c++字符串相关教程,阅读专题下面的文章了解更多详细内容。

131

2025.08.07

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
最新Python教程 从入门到精通
最新Python教程 从入门到精通

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 5.1万人学习

SciPy 教程
SciPy 教程

共10课时 | 2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号