python从数据集中读取日期并对两条折线中间填色

2023-11-07 17:10

本文主要是介绍python从数据集中读取日期并对两条折线中间填色,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 

目录

datetime模块读取时间

折线图填色


在图表中添加日期可以使得图标更加有用。在天气数据文件中,第一个日期在第二行:

“USW00025333”,“SKIKA AIRPORT”,AK US“,”2018-07-01“,”0.25“,,”62“,”50“

读取该数据时,获得的是字符串,因此需要想办法将字符串
”2018-7-1“转化为一个表示相应日期的对象。为创建一个表示2018年七月1日的对象,可使用模块datetime中的方法stptime()

from datetime import datetime
import csv
import matplotlib.pyplot as pltfilename ='data/sitka_weather_2018_simple.csv'#将要使用的文件名赋给filename
with open(filename) as f:#打开这个文件并且把返回的文件对象赋给freader = csv.reader(f) #调用csv.reader()并将前面储存的文件对象作为实参传递给它,从而创建一个与该文件相关联的阅读器对象,这个阅读器的对象被赋给了reader#模块csv中包含函数next(),调用它并传入阅读器对象时,它将返回文件中的下一行。header_row = next(reader)    #文件的第一行中一系列的文件头指出了后续各行包含的是什么样的信息#reader处理文件中以逗号分隔的第一行数据,并将每项数据都作为一个元素储存在列表中#print(header_row)#for index, column_header in enumerate(header_row): 更详细的显示数据#   print(index , column_header)#在知道需要哪些列中的数据后,我们来读取一些数据,从文件中获取最高温度,最低温度和日期:highs,dates,lows= [],[],[]for row in reader:current_date = datetime.strptime(row[2],'%Y-%m-%d')high = int (row[5]) #数据是用字符串存储的,因此转化类型low=int(row[6])dates.append(current_date)highs.append(high)lows.append(row[6])#print(highs)
plt.style.use('seaborn')
plt.rcParams['font.sans-serif'] = ['Arial Unicode MS']
fig,ax =plt.subplots()
ax.plot(dates,highs , c='red',alpha=0.5)#alpha为透明度
ax.plot(dates,lows,c='blue',alpha=0.5)
ax.fill_between(dates,highs,lows,facecolor='blue',alpha=0.1)
#设置图形格式
ax.set_title("2018年7月每日最高温度",fontsize=24)
ax.set_xlabel('',fontsize=16)
fig.autofmt_xdate()#绘制倾斜的日期标签以免重叠
ax.set_ylabel("温度(F)",fontsize=16)
ax.tick_params(axis='both',which ='major',labelsize=16)
plt.show()

datetime模块读取时间

对于datetime模块有很多设置日期和时间的实参

%A 星期几Monday

%B 月份名January

%m 用数字表示的月份

%d 用数字表示的月份中的一天

%Y 四位的年份

%y 两位的年份

%H 24小时的小时数

%I 12小时的小时数

%p am或者pm

%M 分钟数 00—59

%S 秒数 00—61

可以根据我们的需要来进行使用

折线图填色

这边可以使用fill_between的函数来对于两个折线图之间进行颜色的填充,同时可以通过alpha来改变透明度来使得你的图看上去更美观。结果如下显示:

 

 

这篇关于python从数据集中读取日期并对两条折线中间填色的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/365071

相关文章

python panda库从基础到高级操作分析

《pythonpanda库从基础到高级操作分析》本文介绍了Pandas库的核心功能,包括处理结构化数据的Series和DataFrame数据结构,数据读取、清洗、分组聚合、合并、时间序列分析及大数据... 目录1. Pandas 概述2. 基本操作:数据读取与查看3. 索引操作:精准定位数据4. Group

Python pandas库自学超详细教程

《Pythonpandas库自学超详细教程》文章介绍了Pandas库的基本功能、安装方法及核心操作,涵盖数据导入(CSV/Excel等)、数据结构(Series、DataFrame)、数据清洗、转换... 目录一、什么是Pandas库(1)、Pandas 应用(2)、Pandas 功能(3)、数据结构二、安

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

SpringBoot多环境配置数据读取方式

《SpringBoot多环境配置数据读取方式》SpringBoot通过环境隔离机制,支持properties/yaml/yml多格式配置,结合@Value、Environment和@Configura... 目录一、多环境配置的核心思路二、3种配置文件格式详解2.1 properties格式(传统格式)1.

Python实现网格交易策略的过程

《Python实现网格交易策略的过程》本文讲解Python网格交易策略,利用ccxt获取加密货币数据及backtrader回测,通过设定网格节点,低买高卖获利,适合震荡行情,下面跟我一起看看我们的第一... 网格交易是一种经典的量化交易策略,其核心思想是在价格上下预设多个“网格”,当价格触发特定网格时执行买

Python标准库之数据压缩和存档的应用详解

《Python标准库之数据压缩和存档的应用详解》在数据处理与存储领域,压缩和存档是提升效率的关键技术,Python标准库提供了一套完整的工具链,下面小编就来和大家简单介绍一下吧... 目录一、核心模块架构与设计哲学二、关键模块深度解析1.tarfile:专业级归档工具2.zipfile:跨平台归档首选3.

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

解决pandas无法读取csv文件数据的问题

《解决pandas无法读取csv文件数据的问题》本文讲述作者用Pandas读取CSV文件时因参数设置不当导致数据错位,通过调整delimiter和on_bad_lines参数最终解决问题,并强调正确参... 目录一、前言二、问题复现1. 问题2. 通过 on_bad_lines=‘warn’ 跳过异常数据3

Python进行JSON和Excel文件转换处理指南

《Python进行JSON和Excel文件转换处理指南》在数据交换与系统集成中,JSON与Excel是两种极为常见的数据格式,本文将介绍如何使用Python实现将JSON转换为格式化的Excel文件,... 目录将 jsON 导入为格式化 Excel将 Excel 导出为结构化 JSON处理嵌套 JSON: