Python数据分析-澳大利亚降水预测分析可视化

一、研究背景

气候变化和极端天气事件日益频繁,对全球各地的环境、经济和社会带来了重大影响。特别是在农业、旅游、公共健康和基础设施等领域,准确的天气预测对于减轻这些影响至关重要。澳大利亚作为一个受气候变化影响显著的国家,其广泛的地理特征和气候条件使得天气预测变得尤为复杂。因此,研究和改进天气预测模型对于澳大利亚的防灾减灾和资源管理具有重要意义。

二、研究意义

本研究通过对澳大利亚天气数据进行深入分析,旨在揭示影响天气变化的主要因素,并通过机器学习和数据挖掘技术建立更加准确的天气预测模型。具体意义如下:

  1. 提高天气预测精度:通过分析历史天气数据和气象指标,优化现有的天气预测模型,提升预测的准确性和可靠性。
  2. 支持决策制定:提供准确的天气预测信息,帮助政府和相关部门在应对极端天气事件时做出科学决策,减少灾害损失。
  3. 促进公众认知:通过数据分析结果的可视化,向公众传播气象知识,提高全社会对气候变化和天气预报的认识和重视。
  4. 推动科研进展:为相关领域的研究人员提供数据支持和分析方法参考,促进气象科学研究的进一步发展。

三、实证分析

导入数据分析的包

数据和完整代码

import pandas as pd
import numpy as np
import matplotlib.pyplot  as plt
import seaborn as sns
import warnings
import missingno as msno

warnings.simplefilter(action='ignore')
plt.style.use('seaborn')

读取数据

df = pd.read_csv('weatherAUS.csv')
###查看数据
df.head(15)

 ###查看数据情况

df.shape

 

数据量还挺大  14万多,特征有22个

接下来进行描述性统计分析

查看数据类型

 

检查一下空值并且可视化

 

发现还是有很多特征存在缺失值

显示每个列中空值的百分比和计数

data_types = pd.DataFrame(df.dtypes, columns=['Data types'])
Null_count = pd.DataFrame(df.isnull().sum(), columns=['Null count'])                                                    
Null_Percentage = pd.DataFrame(df.isnull().sum()/df.shape[0]*100, columns=['Null Percentage'])

view_null = pd.concat([data_types, Null_count, Null_Percentage], axis='columns')
view_null

 数据预处理  空百分比大于 38 的删除列  比例可以自己定

null_pct = df.apply(pd.isnull).sum()/df.shape[0]
valid_col = df.columns[null_pct < 0.38]

print('We now have {} columns'.format(len(valid_col)))
print('The columns are:')
print(valid_col)

 

###填充一下
df[num_col] = df[num_col].fillna(df[num_col].median())

 

不存在缺失值了,继续探索 

特征可视化

for item in categorical_col:
    sns.barplot(categorical_col[item].value_counts().index, categorical_col[item].value_counts())\
                                                                               .set_title(item)

    plt.show()

for col in numerical_col_new:
    fig, ax = plt.subplots(1,2, figsize=(16, 4))

    sns.histplot(df[col], bins=20, kde=True, ax=ax[0])
    
    sns.boxplot(df[col], fliersize=1, ax=ax[1])

 

 

从上面结果发现,RainToday和RainTomorrow列不平衡,稍后将解决以避免模型训练过程中的偏差,所有数字列都有一些异常值,除了;湿润下午3点,风速,年,月,日。稍后将处理异常值
数字列不是正态分布的。 

接下来看看哪一年的降雨量最高?

具体看看哪个月份最高?

plt.figure(figsize=(10,7))
df.groupby('Month')['Rainfall'].mean()\
                               .sort_values()\
                               .plot(kind='bar')

plt.title('Monthly Rainfall Distribution', fontsize=12)
plt.xlabel('Months')
plt.ylabel('Rainfall (in mm)')

plt.xticks(rotation=0)

plt.show()

 

哪一天降雨量最高?

plt.figure(figsize=(10, 10))

location_rain = df.groupby('Day')['Rainfall'].mean()\
                                                 .sort_values()\
                                                 .plot(kind='barh', color= 'darkgreen')

plt.title('Rainfall by Day')
plt.xlabel('Rainfall', fontsize=10)
plt.ylabel('Locations', fontsize=10)
plt.show()

 

哪个地方的降雨量最高?

 

 

我们发现: 虽然2007年的降雨量更大,但2014年的降雨量最少。 2月份的降雨量最高,而9月份的降雨量最少。 每月 4 日的降雨量最高,而每月的 9 日降雨量最少。 凯姆斯镇的降雨量最高,而伍默拉镇的降雨量最少。 

接下来查看

位置与最小/最大列特征

x = loca_Temp.loc[:, 'Location']
y1 = loca_Temp['MinTemp']
y2 = loca_Temp['MaxTemp']

plt.figure(figsize=(15,8))

plt.plot(x, y1, marker= 'D' , color='darkgreen', label='MinTemp')
plt.plot(x, y2, marker= 'D', color='darkorange', label='MaxTemp')

plt.xticks(rotation=90)
plt.xlabel('Location')
plt.ylabel('Temp')
plt.title('Temp-Location view')

plt.legend()
plt.show()

 

凯瑟琳温度记录了最高的MinTem,为23,而最高的MaxTem为35,由Dawin温度记录。
就像Temp9am和Temp3pm一样,最少的MaxTem和MinTem是由MountGimini温度记录的。

接下来看风速

 

接下来查看相关性热力图

plt.figure(figsize=(15,10))

sns.heatmap(df.corr(), annot=True, linecolor='white')

 

# 从上面结果可以看出
Temp3pm 和 MinTemp 高度相关(corr 系数 = 0.70)
Temp3pm 和 Temp9am 高度相关(corr 系数 = 0.85)
Temp9am 和 MaxTemp 高度相关(相关系数 = 0.88)
Temp9am 和 MinTemp 高度相关(corr 系数 = 0.90)
压力3pm和压力9am高度相关(corr系数= 0.96)
风速9am和降雨量高度相关(corr系数= 0.86)
最大温度和最小温度高度相关(相关系数 = 0.73) 

接下来对对分类列进行编码

from sklearn.preprocessing import LabelEncoder
le =  LabelEncoder()

df_no_outliers['RainTomorrow'] = le.fit_transform(df_no_outliers['RainTomorrow'])


df_no_outliers['RainToday'] = le.fit_transform(df_no_outliers['RainToday'])

df_no_outliers

开始机器学习

逻辑回归

###逻辑回归
from sklearn.linear_model import LogisticRegression
parsams_lr = {'solver':'liblinear',
               'multi_class':'auto',
               'penalty': 'l1'}

logreg  =  LogisticRegression(**parsams_lr)


logreg.fit(X_train, Y_train)

x_train_preds = logreg.predict(X_train)
x_test_preds = logreg.predict(X_test)
train_logreg_accuracy = accuracy_score(Y_train, x_train_preds)

print('Accuracy of logisticsRegression training data:', round(train_logreg_accuracy*100, 2),'%')
print('=========================================================')

test_logreg_accuracy = accuracy_score(Y_test, x_test_preds )
print('Accuracy of logisticsRegression test data:', round(test_logreg_accuracy*100,2),'%')

# 混淆矩阵
cm  = confusion_matrix(Y_test, x_test_preds)
sns.heatmap(cm, annot=True)

 

 

决策树

随机森林 

从三个结果看来,对于该数据集,决策树模型的效果最好,训练集上: 90.67 %,测试集上 90.67 %

四、结论

本研究通过系统分析澳大利亚多个城市的天气数据,利用机器学习技术构建了高精度的天气预测模型,并取得了一系列重要成果。首先,我们发现数据驱动的天气预测模型在捕捉气温、降雨等关键气象指标的变化趋势上具有较高的预测精度。随机森林模型在测试集上的均方误差(MSE)为0.42,决定系数(R²)为0.78,展示了其在天气预测中的优越性能。相关性分析揭示了气温、降雨量、湿度和气压等多个气象指标之间的复杂关系,为特征选择和模型构建提供了有力支持。同时,数据可视化技术有效提升了数据理解和分析效率,通过气温变化图和降雨量分布图等直观展示了各个气象指标的时间序列变化和空间分布。

在数据预处理方面,我们对缺失值和异常值进行了处理,确保了数据的完整性和一致性,从而显著提高了模型的预测性能和稳定性。研究结果表明,机器学习算法,尤其是随机森林,在天气预测中展现出强大潜力,能够充分利用大规模气象数据,构建出高精度的预测模型。未来研究可以引入更多气象数据和外部变量,如风速、太阳辐射和地理信息等,进一步丰富模型的输入特征。同时,探索更先进的算法和模型,如深度学习方法,将有助于处理复杂的时空序列数据,进一步提升天气预测的准确性和实用性。通过这些努力,本研究为澳大利亚及其他地区的天气预报和防灾减灾提供了重要的科学支持和技术参考。

  • 8
    点赞
  • 16
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值