基于Python的北京天气数据可视化分析

项目用到库

import numpy as np
import pandas as pd
import datetime
from pyecharts.charts import Line
from pyecharts.charts import Boxplot
from pyecharts.charts import Pie,Grid
from pyecharts import options as opts
from pyecharts.charts import Calendar

1.2018 年北京AQI全年走势图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')
attr = df['Date'].tolist()  # 将 Date 转换为列表
v1 = df['AQI'].tolist()  # 将 AQI 转换为列表# 创建折线图
line = (Line().add_xaxis(attr).add_yaxis("AQI值:", v1, is_smooth=True, areastyle_opts=opts.AreaStyleOpts(opacity=0.3, color="#000"), markline_opts=opts.MarkLineOpts(data=[opts.MarkLineItem(type_="average")]),markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_="max", name="最大值"),opts.MarkPointItem(type_="min", name="最小值")])).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京AQI全年走势图", pos_top='5%', pos_left='center'),xaxis_opts=opts.AxisOpts(type_="category"),yaxis_opts=opts.AxisOpts(type_="value"))
)# 将图表渲染到 HTML 文件
line.render("./2018年北京AQI全年走势图.html")

结果如下: 

2.2018 年北京PM2.5全年走势图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')
attr = df['Date'].tolist()  # 将 Date 转换为列表
v1 = df['PM'].tolist()  # 将 PM 转换为列表# 创建折线图
line = (Line().add_xaxis(attr).add_yaxis("PM2.5值:", v1, is_smooth=True, areastyle_opts=opts.AreaStyleOpts(opacity=0.3, color="#000"), markline_opts=opts.MarkLineOpts(data=[opts.MarkLineItem(type_="average")]),markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_="max", name="最大值"),opts.MarkPointItem(type_="min", name="最小值")])).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京PM2.5全年走势图", pos_top='5%', pos_left='center'),xaxis_opts=opts.AxisOpts(type_="category"),yaxis_opts=opts.AxisOpts(type_="value"))
)# 将图表渲染到 HTML 文件
line.render("./2018年北京PM2.5全年走势图.html")

结果如下:

3.2018 年北京月均AQI走势图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')# 提取 Date 和 AQI 的值
dom = df[['Date', 'AQI']]# 提取月份
df['month'] = df['Date'].apply(lambda x: x.split('/')[1])# 根据月份分组并计算每月的 AQI 平均值
month_com = df.groupby('month')['AQI'].mean().reset_index()# 排序月份
month_com = month_com.sort_values(by='month')# 构造月份标签
attr = ["{}月".format(i) for i in range(1, 13)]# 获取每月的 AQI 平均值
v1 = month_com['AQI'].tolist()
v1 = ["{}".format(int(i)) for i in v1]# 创建折线图
line = (Line().add_xaxis(attr).add_yaxis("AQI月均值", v1, markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_="max", name="最大值"),opts.MarkPointItem(type_="min", name="最小值")])).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京月均AQI走势图", pos_top='5%', pos_left='center'),xaxis_opts=opts.AxisOpts(type_="category"),yaxis_opts=opts.AxisOpts(type_="value"))
)# 渲染图表到 HTML 文件
line.render("./2018年北京月均AQI走势图.html")

结果如下:

4.2018 年北京月均PM2.5走势图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')# 提取 Date 和 PM 的值
dom = df[['Date', 'PM']]# 提取月份
df['month'] = df['Date'].apply(lambda x: x.split('/')[1])# 根据月份分组并计算每月的 PM 平均值
month_com = df.groupby('month')['PM'].mean().reset_index()# 排序月份
month_com = month_com.sort_values(by='month')# 构造月份标签
attr = ["{}月".format(i) for i in range(1, 13)]# 获取每月的 PM 平均值
v1 = month_com['PM'].tolist()
v1 = ["{}".format(int(i)) for i in v1]# 创建折线图
line = (Line().add_xaxis(attr).add_yaxis("PM2.5月均值", v1, markpoint_opts=opts.MarkPointOpts(data=[opts.MarkPointItem(type_="max", name="最大值"),opts.MarkPointItem(type_="min", name="最小值")])).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京月均PM2.5走势图", pos_top='5%', pos_left='center'),xaxis_opts=opts.AxisOpts(type_="category"),yaxis_opts=opts.AxisOpts(type_="value"))
)# 渲染图表到 HTML 文件
line.render("./2018年北京月均PM2.5走势图.html")

结果如下:

5.2018年北京季度AQI箱形图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')# 提取 Date 和 AQI 的值
dom = df[['Date', 'AQI']]
data = [[], [], [], []]
dom1, dom2, dom3, dom4 = data# 根据季度提取 AQI 值
for date, aqi in zip(dom['Date'], dom['AQI']):month = int(date.split('/')[1])if month in [1, 2, 3]:dom1.append(aqi)elif month in [4, 5, 6]:dom2.append(aqi)elif month in [7, 8, 9]:dom3.append(aqi)else:dom4.append(aqi)# 创建箱形图
boxplot = Boxplot()# 设置 x 轴和 y 轴数据
x_axis = ['第一季度', '第二季度', '第三季度', '第四季度']
y_axis = [dom1, dom2, dom3, dom4]
y_axis = boxplot.prepare_data(y_axis)# 添加数据到箱形图
boxplot.add_xaxis(x_axis)
boxplot.add_yaxis("AQI", y_axis)# 设置图表全局选项
boxplot.set_global_opts(title_opts=opts.TitleOpts(title="2018年北京季度AQI箱形图", pos_left='center', pos_top='6%'))# 渲染图表到 HTML 文件
boxplot.render("./2018年北京季度AQI箱形图.html")

结果如下:

6.2018年北京季度PM2.5箱形图

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')# 提取 Date 和 PM 的值
dom = df[['Date', 'PM']]
data = [[], [], [], []]
dom1, dom2, dom3, dom4 = data# 根据季度提取 PM 值
for date, pm in zip(dom['Date'], dom['PM']):month = int(date.split('/')[1])if month in [1, 2, 3]:dom1.append(pm)elif month in [4, 5, 6]:dom2.append(pm)elif month in [7, 8, 9]:dom3.append(pm)else:dom4.append(pm)# 创建箱形图
boxplot = Boxplot()# 设置 x 轴和 y 轴数据
x_axis = ['第一季度', '第二季度', '第三季度', '第四季度']
y_axis = [dom1, dom2, dom3, dom4]
y_axis = boxplot.prepare_data(y_axis)# 添加数据到箱形图
boxplot.add_xaxis(x_axis)
boxplot.add_yaxis("PM2.5", y_axis)# 设置图表全局选项
boxplot.set_global_opts(title_opts=opts.TitleOpts(title="2018年北京季度PM2.5箱形图", pos_left='center', pos_top='6%'))# 渲染图表到 HTML 文件
boxplot.render("./2018年北京季度PM2.5箱形图.html")

结果如下:

7.2018年北京全年空气质量情况

代码如下:

# 读取数据
df = pd.read_csv('beijing_AQI_2018.csv')# 根据 Quality_grade 分组
rank_message = df.groupby(['Quality_grade'])# 计算每个 Quality_grade 的频数
rank_com = rank_message['Quality_grade'].agg(['count'])
rank_com.reset_index(inplace=True)  # 重置索引
rank_com_last = rank_com.sort_values('count', ascending=False)  # 从大到小排序# 提取 Quality_grade 和对应的频数
attr = rank_com_last['Quality_grade'].tolist()
v1 = rank_com_last['count'].tolist()# 创建饼图
pie = (Pie().add("", [list(z) for z in zip(attr, v1)], radius=["40%", "75%"], label_opts=opts.LabelOpts(is_show=True, formatter="{b}: {d}%")).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京全年空气质量情况", pos_left='center', pos_top='0'),legend_opts=opts.LegendOpts(is_show=True, orient="vertical", pos_left="left", pos_top="10%"))
)# 渲染图表到 HTML 文件
pie.render('./2018年北京全年空气质量情况.html')

结果如下:

8.2018年北京PM2.5指数日历图

代码如下:

# Read data from 'beijing_AQI_2018.csv'
df = pd.read_csv('beijing_AQI_2018.csv')# Extract 'Date' and 'PM' columns
dom = df[['Date', 'PM']]list1 = []# Compress the date and PM values into a list of lists
for i, j in zip(dom['Date'], dom['PM']):time_list = i.split('/')time = datetime.date(int(time_list[0]), int(time_list[1]), int(time_list[2]))PM = int(j)list1.append([str(time), PM])# Create a calendar chart
calendar = (Calendar(init_opts=opts.InitOpts(width="800px", height="400px")).add(series_name="2018年北京PM2.5指数日历图",yaxis_data=list1,calendar_opts=opts.CalendarOpts(range_="2018"),).set_global_opts(title_opts=opts.TitleOpts(title="2018年北京PM2.5指数日历图", pos_left="center",pos_top='50%'),visualmap_opts=opts.VisualMapOpts(max_=300, min_=0, orient="horizontal", is_piecewise=True,pos_top='60%',  # 将视觉映射放置在图表的顶部pos_left='center'  # 将视觉映射放置在图表的水平居中位置),)
)# Render the chart to an HTML file
calendar.render('./2018年北京PM2.5指数日历图.html')

结果如下:

9.2018 年北上广深AQI全年走势图

代码如下:


citys = ['beijing', 'shanghai', 'guangzhou', 'shenzhen']
cityes_AQI = []# 遍历四个城市的数据
for city in citys:filename = city + '_AQI' + '_2018.csv'aqi_data = pd.read_csv(filename)# 提取日期和AQI指数两列内容get_data = aqi_data[['Date', 'AQI']]# 获取每行数据的月份month_for_data = [j.split('/')[1] for j in get_data['Date']]aqi_data['Month'] = month_for_data# 求每个月AQI平均值month_AQI = aqi_data.groupby(['Month'])['AQI'].mean().reset_index()# 获取每个城市月均AQI的数据,转化为int数据类型city_AQI_data_int = month_AQI['AQI'].astype(int).tolist()cityes_AQI.append(city_AQI_data_int)months = [str(i) + '月' for i in range(1, 13)]line = (Line(init_opts=opts.InitOpts(width="800px", height="400px")).add_xaxis(months).add_yaxis("北京", cityes_AQI[0], color='red', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("上海", cityes_AQI[1], color='purple', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("广州", cityes_AQI[2], color='blue', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("深圳", cityes_AQI[3], color='orange', label_opts=opts.LabelOpts(is_show=False)).set_global_opts(title_opts=opts.TitleOpts(title="2018年北上广深AQI全年走势图", pos_left='center', pos_top='0'),legend_opts=opts.LegendOpts(orient="horizontal", pos_top="8%"),)
)line.render('./2018年北上广深AQI全年走势图.html')  # 生成HTML文件,保存在当前目录下

结果如下:

10.2018 年北上广深PM2.5全年走势图

代码如下:

import numpy as np
import pandas as pd
from pyecharts.charts import Line
from pyecharts import options as optscitys = ['beijing', 'shanghai', 'guangzhou', 'shenzhen']
cityes_AQI = []# 遍历四个城市的数据
for city in citys:filename = city + '_AQI' + '_2018.csv'aqi_data = pd.read_csv(filename)# 提取日期和PM2.5指数两列内容get_data = aqi_data[['Date', 'PM']]# 获取每行数据的月份month_for_data = [j.split('/')[1] for j in get_data['Date']]aqi_data['Month'] = month_for_data# 求每个月PM2.5平均值month_AQI = aqi_data.groupby(['Month'])['PM'].mean().reset_index()# 获取每个城市月均PM2.5的数据,转化为int数据类型city_AQI_data_int = month_AQI['PM'].astype(int).tolist()cityes_AQI.append(city_AQI_data_int)months = [str(i) + '月' for i in range(1, 13)]line = (Line(init_opts=opts.InitOpts(width="800px", height="400px")).add_xaxis(months).add_yaxis("北京", cityes_AQI[0], color='red', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("上海", cityes_AQI[1], color='purple', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("广州", cityes_AQI[2], color='blue', label_opts=opts.LabelOpts(is_show=False)).add_yaxis("深圳", cityes_AQI[3], color='orange', label_opts=opts.LabelOpts(is_show=False)).set_global_opts(title_opts=opts.TitleOpts(title="2018年北上广深PM2.5全年走势图", pos_left='center', pos_top='0'),legend_opts=opts.LegendOpts(orient="horizontal", pos_top="8%"),)
)line.render('./2018年北上广深PM2.5全年走势图.html')  # 生成HTML文件,保存在当前目录下

结果如下:

11.2018 年北上广深全年空气质量情况

代码如下:

citys = ['beijing', 'shanghai', 'guangzhou', 'shenzhen']
v = []
attrs = []
for i in range(4):filename =  citys[i] + '_AQI' + '_2018.csv'df = pd.read_csv(filename)# 根据 Quality_grade 分组Quality_grade_message = df.groupby(['Quality_grade'])# 每组的频数Quality_grade_com = Quality_grade_message['Quality_grade'].agg(['count'])Quality_grade_com.reset_index(inplace=True)Quality_grade_com_last = Quality_grade_com.sort_values('count', ascending=False)# 取 Quality_grade 的值Quality_grade_array = Quality_grade_com_last['Quality_grade'].values.tolist()attrs.append(Quality_grade_array)Quality_grade_count = Quality_grade_com_last['count'].values.tolist()v.append(Quality_grade_count)# 创建饼图并设置属性
pie1 = (Pie().add("北京", [list(z) for z in zip(attrs[0], v[0])], radius=["20%", "40%"], center=["30%", "27%"],).set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%")).set_global_opts(title_opts=opts.TitleOpts(title="北京", pos_left='27%', pos_top='25%'),legend_opts=opts.LegendOpts(orient="vertical", pos_right="5%", pos_top="35%"))
)pie2 = (Pie().add("上海", [list(z) for z in zip(attrs[1], v[1])], radius=["20%", "40%"], center=["70%", "27%"],).set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%")).set_global_opts(title_opts=opts.TitleOpts(title="上海", pos_left='67%', pos_top='25%'),legend_opts=opts.LegendOpts(is_show=False))
)pie3 = (Pie().add("广州", [list(z) for z in zip(attrs[2], v[2])], radius=["20%", "40%"], center=["30%", "77%"],).set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%")).set_global_opts(title_opts=opts.TitleOpts(title="广州", pos_left='27%', pos_top='75%'),legend_opts=opts.LegendOpts(is_show=False))
)pie4 = (Pie().add("深圳", [list(z) for z in zip(attrs[3], v[3])], radius=["20%", "40%"], center=["70%", "77%"],).set_series_opts(label_opts=opts.LabelOpts(formatter="{b}: {d}%")).set_global_opts(title_opts=opts.TitleOpts(title="深圳", pos_left='67%', pos_top='75%'),legend_opts=opts.LegendOpts(is_show=False))
)# 创建 Grid 并添加饼图
grid = (Grid().add(pie1, grid_opts=opts.GridOpts(pos_left="5%", pos_right="50%", pos_top="10%")).add(pie2, grid_opts=opts.GridOpts(pos_left="55%", pos_right="5%", pos_top="10%")).add(pie3, grid_opts=opts.GridOpts(pos_left="5%", pos_right="50%", pos_top="50%")).add(pie4, grid_opts=opts.GridOpts(pos_left="55%", pos_right="5%", pos_top="50%"))
)grid.render('./2018年北上广深全年空气质量情况.html')

结果如下:

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

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

相关文章

Python应用开发——30天学习Streamlit Python包进行APP的构建(5)

上几次我们已经将一些必备的内容进行了快速的梳理,让我们掌握了streanlit的凯快速上手,接下来我们将其它的一些基础函数再做简单的梳理,以顺便回顾我们未来可能用到的更丰富的函数来实现应用的制作。 st.write_stream 将生成器、迭代器或类似流的序列串流到应用程序中。 …

vue -ant -design 卡片是布局 实现动态计算 当前的 左右间距 实现居中

是这样的一个样式 我们使用display :flex 布局的时候 我们全部剧中 display: flex;align-items: center;justify-content: center; 如果是上述的代码来说的话 总是最后的一个也是会居中的 这样就比较丑 我们好像就没有什么好的办法了 我们这自己写的 肯定没有组件牛 如果有…

三十六篇:未来架构师之道:掌握现代信息系统典型架构

未来架构师之道:掌握现代信息系统典型架构 1. 引言 在企业的数字化转型浪潮中,信息系统架构的角色变得日益重要。它不仅承载了企业的IT战略,更是确保企业在复杂、动态的市场环境中稳定运行的关键。作为信息系统的骨架,一个精心设…

Linux环境在非root用户中搭建(java-tomcat-redis)

注: 本文在内网(离线)环境,堡垒机中搭建,服务器不同可能有所差异,仅供参考 本文安装JDK-20.0.1版本,apache-tomcat-10.1.10版本,redis-6.2.15版本 本文服务器IP假设:192.168.88.133 root用户创建子用户并…

人工智能对话系统源码 手机版+电脑版二合一 全端支持 前后端分离 带完整的安装代码包以及搭建部署教程

系统概述 该系统采用前后端分离的设计模式,前端负责用户界面展示与交互,后端负责数据处理与业务逻辑实现。前后端通过API接口进行通信,实现数据的实时传输与处理。系统支持全端访问,无论是手机还是电脑,都能获得良好的…

u盘内容无故消失了是什么原因?u盘部分内容无故消失了怎么恢复

在数字化时代,U盘作为便携存储设备,承载着许多重要的数据。然而,有时我们可能会遭遇U盘部分内容无故消失的情况,这无疑给我们的工作和生活带来了不小的困扰。本文将为您解析U盘内容消失的可能原因,并分享几招实用的数据…

重生奇迹MU格斗家技能

格斗家有9个技能,其中幽冥青狼拳.斗气爆裂拳.神圣气旋.这3个是武器上带的技能。 回旋踢.幽冥光速拳.炎龙拳.这3个是买羊皮纸学的技能(回旋踢是格斗最强技能)。 还有3个给自己加BUFF的技能,斗神破(增加无视防御的状态&…

移动端 UI 风格,视觉盛宴

移动端 UI 风格,视觉盛宴

linux常用命令及其选项

1、常用命令 1.1、ls 选项说明-a显示所有文件及目录 (包括隐藏文件)-i显示inode-A同 -a选项 ,但不列出 "." (目前目录) 及 ".." (父目录)-l列出信息详细(如文件型态、权限、拥有者、文件大小等)-R递归显示(若目录下有文件,则以下之…

htb_office

端口扫描 namp -sSVC 10.10.11.1380,445 80端口 robots.txt 只有/administrator可以访问 Joomla joomscan扫描 joomscan --url http://10.10.11.3/ 版本为4.2.7,存在cve CVE-2023-23752 Joomla未授权访问Rest API漏洞 访问路径 /api/index.php/…

使用OpenCV dnn c++加载YOLOv8生成的onnx文件进行实例分割

在网上下载了60多幅包含西瓜和冬瓜的图像组成melon数据集,使用 EISeg 工具进行标注,然后使用 eiseg2yolov8 脚本将.json文件转换成YOLOv8支持的.txt文件,并自动生成YOLOv8支持的目录结构,包括melon.yaml文件,其内容如下…

Linux宝塔部署数据库连接问题

博主在部署项目时发现网页可以成功部署,但是登录界面一直登录不进去推测是数据库连接问题。 博主当时在IDEA中写的是用户名为root 密码123456 但是在宝塔中因为自己是跟着教程学的所以就顺手把用户名和密码都改了,于是java中的配置和数据库配置连接不上…

利用streamlit结合langchain_aws实现claud3的页面交互

测试使用的代码如下 import streamlit as st from langchain_aws import ChatBedrockdef chat_with_model(prompt, model_id):llm ChatBedrock(credentials_profile_name"default", model_idmodel_id, region_name"us-east-1")res llm.invoke(prompt)re…

mathtype最新注册码下载2024最新分享地址

数学公式编辑器MathType,让在线教育更“数”利 在当今这个数字化、信息化飞速发展的时代,无论是学术研究、教育教学还是日常工作中,都离不开对各种复杂公式的输入与编辑。特别是对于教育工作者和科研工作者而言,如何高效准确地输入…

C++开源项目:pathcopycopyV20源码及运行程序

PathCopyCopy 是一个开源的 Windows 资源管理器扩展项目,旨在为用户提供一个更加高效、便捷的文件路径复制和管理工具。以下是关于 PathCopyCopy 开源项目的详细介绍: 1. 项目概述 2. 项目技术分析 3. 项目功能 4. 项目特点 5. 项目应用场景 6. 项目…

8. C#多线程基础概念

文章目录 一. 目标二. 技能介绍① 进程和线程② 为什么需要多线程③ C#实现多线程的方式④ 线程的操作(创建_终止_挂起_恢复) 一. 目标 进程和线程基本概念为什么需要多线程?C#实现多线程的方式?线程Thread的创建,终止,挂起和恢复? 二. 技能介绍 ① 进程和线程 什么是进程…

计网总结☞物理层

五层协议体系结构->各层的功能有: 物理层 物理层的任务就是尽可能地屏蔽传输媒体的差异,透明地传送比特流(注意:传递信息的物理媒体,如双绞线、同轴电缆、光缆等,是在物理层的下面,当做第 0…

Python AI 编程助手:Fitten Code插件

一. 简介 今天为大家推荐一款适配了 Viusal Studio,VS Code(本文使用),JetBrains 系列(本文使用)以及Vim等多种编译器环境的插件 Fitten Code,Fitten Code 是由非十大模型驱动的 AI 编程助手,它可以自动生成代码,提升…

【AIGC】基于大模型+知识库的Code Review实践

一、背景描述 一句话介绍就是:基于开源大模型 知识库的 Code Review 实践,类似一个代码评审助手(CR Copilot)。信息安全合规问题:公司内代码直接调 ChatGPT / Claude 会有安全/合规问题,为了使用 ChatGPT…

STM32F103C8开发板 STM32最小系统核心板 AD硬件原理图+PCB封装文件分享

STM32F103C8开发板原理图 原理图和PCB下载地址: STM32F103C8开发板 STM32最小系统核心板 AD硬件原理图PCB封装文件.zip: https://url83.ctfile.com/f/45573183-1269573020-8f85b2?p7526 (访问密码: 7526)