0

0

如何在Python中将两个循环合并,使后续计算基于前一个循环的每个中间结果

花韻仙語

花韻仙語

发布时间:2026-03-11 19:08:11

|

571人浏览过

|

来源于php中文网

原创

本文详解如何正确嵌套循环结构,确保每次随机生成的数值都独立驱动完整的机器学习建模与评估流程,避免仅对最后一个值执行计算的常见缩进错误。

本文详解如何正确嵌套循环结构,确保每次随机生成的数值都独立驱动完整的机器学习建模与评估流程,避免仅对最后一个值执行计算的常见缩进错误。

在您的原始代码中,问题核心在于作用域与缩进逻辑错误:第一个 for 循环仅执行了 randint() 生成和打印操作,而后续所有模型训练、预测与 R² 计算代码未被包含在该循环内,导致它们只在循环结束后运行一次——且此时 value 已被赋值为最后一次迭代的结果(即 35),因此 for n in [value] 实际等价于 for n in [35]。

要实现“对每一个随机数都完整执行一次建模与评估”,必须将整个建模流程整体缩进至第一层循环内部,使其成为循环体的一部分。以下是修正后的专业级实现:

from random import seed, randint
from sklearn.model_selection import train_test_split
from sklearn.ensemble import GradientBoostingRegressor, RandomForestRegressor
from sklearn.svm import SVR
from sklearn.preprocessing import StandardScaler
from sklearn.pipeline import make_pipeline
from sklearn.ensemble import StackingRegressor

# 设置全局随机种子(影响randint,但不直接影响sklearn模型)
seed(4)

# 存储每次迭代的R²结果,便于后续分析
r2_scores = []

for _ in range(20):
    n = randint(0, 100)  # 直接用n替代value,语义更清晰
    print(n, end=', ')

    # 每次使用不同的random_state进行数据划分,保证实验独立性
    X_train, X_test, y_train, y_test = train_test_split(
        df3_X1, df3_Y1, 
        test_size=0.25, 
        random_state=n
    )

    # 定义超参数与基学习器
    params = {
        'n_estimators': 500,
        'max_depth': 4,
        'min_samples_split': 5,
        'learning_rate': 0.01,
        'loss': 'ls'
    }

    estimators = [
        ('svr', make_pipeline(StandardScaler(), SVR(kernel='rbf', C=0.6))),
        ('gb', GradientBoostingRegressor(random_state=0))
    ]

    # 构建堆叠模型(注意:final_estimator的random_state也建议设为n或固定值以增强可复现性)
    stack = StackingRegressor(
        estimators=estimators,
        final_estimator=RandomForestRegressor(n_estimators=100, random_state=0)
    )

    # 训练与预测
    Final_model = stack.fit(X_train, y_train)
    predictions = Final_model.predict(X_test)

    # 手动计算R²(等价于sklearn.metrics.r2_score,但显式展示逻辑)
    y_bar = y_test.mean()
    ss_tot = ((y_test - y_bar) ** 2).sum()
    ss_res = ((y_test - predictions) ** 2).sum()
    r2_score_val = 1 - (ss_res / ss_tot) if ss_tot != 0 else 0

    print(f"r2_score is {r2_score_val:.6f}")
    r2_scores.append((n, r2_score_val))

print('\nThe for loop is complete!')
print(f"Total evaluations: {len(r2_scores)}")

关键修正点说明:

A1.art
A1.art

一个创新的AI艺术应用平台,旨在简化和普及艺术创作

下载
  • 缩进即逻辑:所有建模、分割、训练、评估代码均缩进至 for _ in range(20): 下,确保每轮迭代独立执行;
  • 变量命名优化:直接使用 n 作为循环内随机数变量,避免 value → [value] 的冗余转换;
  • 结果结构化记录:通过 r2_scores.append((n, r2_score_val)) 显式保存每次的 random_state 与对应 R²,支持后续统计分析(如寻找最优 n);
  • 数值稳定性防护:添加 if ss_tot != 0 判断,防止因 y_test 方差为零导致除零错误;
  • 可复现性提示:虽 GradientBoostingRegressor 和 RandomForestRegressor 中 random_state=0 固定,但若需完全依赖 n 控制全部随机性,可将其替换为 random_state=n(需确保各组件兼容)。

⚠️ 注意事项:

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

  • 此类多轮随机实验会显著增加计算开销。如需高效调参,推荐改用 GridSearchCV 或 RandomizedSearchCV;
  • train_test_split 的 random_state=n 仅控制数据划分的随机性,模型内部随机性由各自 random_state 参数决定;
  • 若目标是评估不同 random_state 对模型稳定性的敏感度,建议额外记录标准差、置信区间等统计量。

通过以上重构,您将获得全部 20 个 r2_score 输出,真正实现“每个随机数驱动一次完整评估”的预期目标。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
if什么意思
if什么意思

if的意思是“如果”的条件。它是一个用于引导条件语句的关键词,用于根据特定条件的真假情况来执行不同的代码块。本专题提供if什么意思的相关文章,供大家免费阅读。

846

2023.08.22

append用法
append用法

append是一个常用的命令行工具,用于将一个文件的内容追加到另一个文件的末尾。想了解更多append用法相关内容,可以阅读本专题下面的文章。

348

2023.10.25

python中append的用法
python中append的用法

在Python中,append()是列表对象的一个方法,用于向列表末尾添加一个元素。想了解更多append的更多内容,可以阅读本专题下面的文章。

1080

2023.11.14

python中append的含义
python中append的含义

本专题整合了python中append的相关内容,阅读专题下面的文章了解更多详细内容。

185

2025.09.12

Go高并发任务调度与Goroutine池化实践
Go高并发任务调度与Goroutine池化实践

本专题围绕 Go 语言在高并发任务处理场景中的实践展开,系统讲解 Goroutine 调度模型、Channel 通信机制以及并发控制策略。内容包括任务队列设计、Goroutine 池化管理、资源限制控制以及并发任务的性能优化方法。通过实际案例演示,帮助开发者构建稳定高效的 Go 并发任务处理系统,提高系统在高负载环境下的处理能力与稳定性。

22

2026.03.10

Kotlin Android模块化架构与组件化开发实践
Kotlin Android模块化架构与组件化开发实践

本专题围绕 Kotlin 在 Android 应用开发中的架构实践展开,重点讲解模块化设计与组件化开发的实现思路。内容包括项目模块拆分策略、公共组件封装、依赖管理优化、路由通信机制以及大型项目的工程化管理方法。通过真实项目案例分析,帮助开发者构建结构清晰、易扩展且维护成本低的 Android 应用架构体系,提升团队协作效率与项目迭代速度。

48

2026.03.09

JavaScript浏览器渲染机制与前端性能优化实践
JavaScript浏览器渲染机制与前端性能优化实践

本专题围绕 JavaScript 在浏览器中的执行与渲染机制展开,系统讲解 DOM 构建、CSSOM 解析、重排与重绘原理,以及关键渲染路径优化方法。内容涵盖事件循环机制、异步任务调度、资源加载优化、代码拆分与懒加载等性能优化策略。通过真实前端项目案例,帮助开发者理解浏览器底层工作原理,并掌握提升网页加载速度与交互体验的实用技巧。

93

2026.03.06

Rust内存安全机制与所有权模型深度实践
Rust内存安全机制与所有权模型深度实践

本专题围绕 Rust 语言核心特性展开,深入讲解所有权机制、借用规则、生命周期管理以及智能指针等关键概念。通过系统级开发案例,分析内存安全保障原理与零成本抽象优势,并结合并发场景讲解 Send 与 Sync 特性实现机制。帮助开发者真正理解 Rust 的设计哲学,掌握在高性能与安全性并重场景中的工程实践能力。

216

2026.03.05

PHP高性能API设计与Laravel服务架构实践
PHP高性能API设计与Laravel服务架构实践

本专题围绕 PHP 在现代 Web 后端开发中的高性能实践展开,重点讲解基于 Laravel 框架构建可扩展 API 服务的核心方法。内容涵盖路由与中间件机制、服务容器与依赖注入、接口版本管理、缓存策略设计以及队列异步处理方案。同时结合高并发场景,深入分析性能瓶颈定位与优化思路,帮助开发者构建稳定、高效、易维护的 PHP 后端服务体系。

412

2026.03.04

热门下载

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

精品课程

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

共4课时 | 22.5万人学习

Django 教程
Django 教程

共28课时 | 4.9万人学习

SciPy 教程
SciPy 教程

共10课时 | 1.9万人学习

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

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