温度预测 python | 使用 Python 可以使用机器学习模型进行温度预测

news2025/1/12 21:45:01

使用 Python 可以使用机器学习模型进行温度预测。常用的模型有回归分析、随机森林等。使用前需要准备足够的历史数据并进行特征工程,构建模型并进行训练,最后使用预测结果。

文章目录

    • 温度预测 回归分析
      • 导入必要的库:
      • 读取温度数据:
      • 分离特征和标签:
      • 分割数据集:
      • 训练模型:
      • 预测结果:
      • 评估:
    • 温度预测 随机森林 Python 写法

温度预测 回归分析

以下代码使用线性回归算法对温度数据进行预测:

import pandas as pd
import numpy as np
from sklearn.linear_model import LinearRegression
from sklearn.model_selection import train_test_split

# 读入温度数据
data = pd.read_csv('temperature_data.csv')

# 分离特征和标签
X = data[['day_of_year', 'year']]
y = data['temperature']

# 分割数据集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2)

# 训练模型
reg = LinearRegression().fit(X_train, y_train)

# 预测结果
y_pred = reg.predict(X_test)

# 评估模型
score = reg.score(X_test, y_test)
print('R2 score: ', score)

导入必要的库:

  • import pandas as pd:用于读取 CSV 文件并处理数据。
  • import numpy as np:用于进行数值运算。
  • from sklearn.linear_model import LinearRegression:从 scikit-learn 库导入线性回归模型。
  • from sklearn.model_selection import train_test_split:从 scikit-learn 库导入数据分割函数。

读取温度数据:

  • data = pd.read_csv('temperature_data.csv'):使用 pandas 读取 CSV 文件并保存到 data 变量中。

分离特征和标签:

  • X = data[['day_of_year', 'year']]:将温度数据中的 day_of_year 和 year 列作为特征,存储到 X 变量中。
  • y = data['temperature']:将温度数据中的 temperature 列作为标签,存储到 y 变量中。

分割数据集:

  • X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2):使用 train_test_split() 函数将数据分为训练集和测试集,其中测试集大小为 20%。

训练模型:

  • reg = LinearRegression().fit(X_train, y_train):使用训练集数据训练线性回归模型,并保存到 reg 变量中。

预测结果:

  • y_pred = reg.predict(X_test):使用测试集数据预测结果,并保存到 y_pred 变量中。

评估:

  • print('R-squared:', reg.score(X_test, y_test)):使用 R-squared 值评估模型的预测精度,其值越接近 1,表示模型预测精度越高。

temperature_data.csv 文件是一个温度数据的 CSV 文件,可能包含以下字段:

day_of_year,year,temperature
1,2021,20.5
2,2021,21.6
3,2021,22.7
365,2021,19.4
1,2022,18.5
2,2022,19.6

day_of_year 列表示一年中的第几天,year 列表示该天的年份,temperature 列表示该天的温度。

运行代码得到下述截图。

温度预测 python | 使用 Python 可以使用机器学习模型进行温度预测

温度预测 随机森林 Python 写法

以下是随机森林回归的 Python 代码:

import pandas as pd
from sklearn.ensemble import RandomForestRegressor
from sklearn.model_selection import train_test_split

# 读取温度数据
data = pd.read_csv('temperature_data.csv')

# 分离特征和标签
X = data[['day_of_year', 'year']]
y = data['temperature']

# 分割数据集
X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2)

# 训练模型
reg = RandomForestRegressor(n_estimators=100).fit(X_train, y_train)

# 预测结果
y_pred = reg.predict(X_test)

# 评估模型
print('R-squared:', reg.score(X_test, y_test))

代码说明如下:

  • import pandas as pd :导入 pandas 库。
  • from sklearn.ensemble import RandomForestRegressor :导入随机森林回归算法。
  • from sklearn.model_selection import train_test_split :导入数据集分割工具。
  • data = pd.read_csv('temperature_data.csv') :读取温度数据。
  • X = data[['day_of_year', 'year']] :提取特征数据(特征:一年中的第几天和年份)。
  • y = data['temperature'] :提取标签数据(标签:温度)。
  • X_train, X_test, y_train, y_test = train_test_split(X, y, test_size=0.2) :将数据集分为训练集和测试集,其中测试集的数据占 20%。
  • reg = RandomForestRegressor(n_estimators=100).fit(X_train, y_train) :使用随机森林回归算法训练模型。
  • y_pred = reg.predict(X_test) :使用训练好的模型对测试集数据进行预测。
  • print('R-squared:', reg.score(X_test, y_test)):使用 R-squared 值评估模型的预测精度,其值越接近 1,表示模型预测精度越高。

代码运行结果:

温度预测 python | 使用 Python 可以使用机器学习模型进行温度预测

📢📢📢📢📢📢
💗 你正在阅读 【梦想橡皮擦】 的博客
👍 阅读完毕,可以点点小手赞一下
🌻 发现错误,直接评论区中指正吧
📆 橡皮擦的第 855 篇原创博客

👇 全网 6000+人正在学习的 爬虫专栏 👇👇👇👇

  • ⭐️ Python 爬虫 120,点击订购 ⭐️
  • ⭐️ 爬虫 100 例教程,点击订购 ⭐️

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/188098.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Java中的插入排序和希尔排序

插入排序&&希尔排序插入排序希尔排序上一篇博客我给大家伙说了一下子堆排序,之所以我把插入排序和希尔排序放在一起呢,是因为希尔排序实际上用到了插入排序的思想,希望下面的内容能够帮助到大家.对于插入排序呢,我们可以参考抓牌顺牌,就在一般情况下,我们也不考虑什么组…

对象在Eden区分配

一、对象在Eden区分配大多数情况下,对象在新生代中 Eden 区分配。当 Eden 区没有足够空间进行分配时,虚拟机将发起一次Minor GC。在测试之前我们先来看看 Minor GC和Full GC 有什么不同呢?Minor GC/Young GC:指发生新生代的的垃圾…

oracle11g SAP测试机归档日志暴增排查(二)

接上面一的内容,通过logminer可以知道是因为oracle11g设置awr快照引起的插入数据,所以要看这个插入是否正常。 之前也发现SYSAUX表空间也没有多少了,应该这个原因引起产生大量的日志 6、查找SYSAUX表空间满的原因 对于SYSAUX表空间而言&…

【博学谷学习记录】大数据课程-学习第五周总结

Hadoop概述 Hadoop介绍 Hadoop是Apache旗下的一个用java语言实现开源软件框架,是一个开发和运行处理大规模数据的软件平台。允许使用简单的编程模型在大量计算机集群上对大型数据集进行分布式处理。 狭义上说,Hadoop指Apache这款开源框架,它…

Gateway, Zuul, Oauth2.0, 前后端分离, 定制页面,登录回调接口的处理

由于公司与Alexa平台接入了语音控制的功能,需要将公司的账号与Alexa的账号进行绑定,所以需要账号授权的操作,也就是使用授权码模式。开发过程中遇到了很多坑,网上关于前后端分离的定制页面的介绍又很少,前前后后花了一…

泰拉瑞亚灾厄NPC不复活x哥布林军队入侵中断

文章首发及后续更新:https://mwhls.top/4415.html,无图/无目录/格式错误/更多相关请至首发页查看。 新的更新内容请到mwhls.top查看。 欢迎提出任何疑问及批评,非常感谢! 目录 NPC 不复活 原因 解决办法 哥布林军队入侵中断 说…

2019-ICML-Towards Graph Pooling by Edge Contraction

2019-ICML-Towards Graph Pooling by Edge Contraction Paper: https://graphreason.github.io/papers/17.pdf Code: https://github.com/Jiajia43/pytorch_geometric 通过边收缩实现图池化 池化层可以使GNN对抽象的节点组而不是单个节点进行推理,从而增加其泛化潜…

MongoDB下载安装

MongoDB 是一个基于分布式文件存储的数据库。由 C 语言编写,旨在为 WEB 应用提供可扩展的高性能数据存储解决方案。 MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。 (摘…

音频编辑服务UI SDK接入指导及常见问题

华为 HMS Core 音频编辑服务(Audio Editor Kit)是华为帮助全球开发者快速构建各类应用音频能力的服务,汇聚了华为在音乐、语音等相关音频领域的先进技术。音频编辑服务为开发者们提供音频基础编辑、AI配音、音源分离、空间渲染、变声、多种音…

IT自动化运维体系的搭建

大家好,我是技福的小咖老师。 对于构建IT运维管理系统而言,如何使用系统的方法来改善运维服务,以及对运维过程进行全面审查尤为重要。今天我们就来讲讲IT自动化运维体系的搭建。 设立IT运维优先原则 优先处理原则是指定义出IT运维的每个关键…

JAVA工具-JDK、JRE、JVM、JIT

目录 概要 JDK和JRE区别 JAVA工具间的联系 JAVA源代码如何被操作系统执行 补充:JIT 概要 JDK:Java Developers Kit-Java开发工具 JRE:Java Runtime Environment-Java运行环境 JVM:Java Virtual Machine-Java虚拟机 JIT:J…

阿里的又一款数据高效同步工具DataX,真香!

我们公司有个项目的数据量高达五千万,但是因为报表那块数据不太准确,业务库和报表库又是跨库操作,所以并不能使用 SQL 来进行同步。当时的打算是通过 mysqldump 或者存储的方式来进行同步,但是尝试后发现这些方案都不切实际&#…

MySQL的回表

核心问题 什么是回表? 答: 回表是一个过程,是获取到主键后再通过主键去查询数据的一个过程就叫回表。 那这个主键从哪来? 从叶子结点存储的内容来,如果存储的是非聚簇索引则通过叶子节点存储的值获取,该值…

机器学习笔记之生成对抗网络(一)逻辑介绍

机器学习笔记之生成对抗网络——逻辑介绍引言生成对抗网络——示例生成对抗网络——数学语言描述生成对抗网络——判别过程描述引言 本节将介绍生成对抗网络的基本逻辑与数学语言描述。 生成对抗网络——示例 生成对抗网络(Generative Adversarial Networks,GAN)&#xff0c…

视觉 → 检测提取

目标检测任务非常有趣且具有挑战性。有些任务非常复杂,需要更多数据才能有所产出。但在这篇文章中,我将展示一个符号检测的小任务,它可以用更少的数据完成。该项目的目的是使用计算机视觉技术从一组给定的图像中提取文本并检测各种符号。在这…

UniApp已经接了手机数据线,但运行工具警告 “没有检查到设备“ (华为手机为例 进行解决)

大部分第一次使用uni进行手机调试都会遇到这个问题 首先 将手机的数据线插入电脑的usb接口是必备前提 然后 就是手机的权限拦截了设备扫描 这就是uni工具找不到设备的原因 接入手机线后 数据会弹出一个USB的提示 点进去之后 我们要设置 允许传输文件 千万别仅充电 接下来的…

Java 以数据流的形式发送数据request Java 数据封装到request中

Java 以数据流的形式发送数据request Java 数据封装到request中 一、描述 1、在做微信支付结果通知的时候,看到一个描述:微信会把相关支付结果及用户信息通过数据流的形式发送给商户 ,那么java如何通过数据流的形式发送数据呢? 二…

idea中的Debug工具的使用介绍

文章目录1、设置断点给断点添加条件2、打开DebugDebu启动方式3、Debug功能介绍左侧功能区顶部功能区使用Debug工具时要先进行打断点的操作1、设置断点 断点就是程序运行暂停的位置,在这个位置以后可以根据自己的操作一步一步的执行程序。 idea中设置断点&#xff1…

FreeMarker基础知识

1、总览 官网:http://freemarker.foofun.cn/ 视频地址:https://www.bilibili.com/video/BV1zZ4y1u7iA 2、FreeMarker概述 2.1 FreeMarker概念 FreeMarker 是⼀款 模板引擎: 即⼀种基于模板和要改变的数据, 并⽤来⽣成输出⽂本(…

动态化护眼全新体验,被誉为“护眼神器”的南卡护眼台灯Pro评测出炉

自从家中的孩子上小学后,随着课后作业的逐渐增加,在书房学习时间更长了,由于平时关注到孩子用眼习惯,眼睛有些轻度近视。作为年轻一代的家长,对孩子的用眼健康方面一定要重视,在照明方面,护眼台…