对dataframe类型 时序数据按时间(戳)先后顺序排序并作图

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
import pandas as pd
df = pd.read_csv('data.txt',sep=',')#读入时间戳数据
print (df)
timeseries = pd.to_datetime(df['Date'])
plt.plot(timeseries,df['Data'],'o-b')
# plt.gca()函數獲得當前坐標軸,然後才能設置參數或作圖,plt.plot()內部實現了這一步驟
plt.gca().xaxis.set_major_formatter(mdates.DateFormatter('%y-%m-%d %H:%M'))  #設置x軸主刻度顯示格式(日期)
# plt.gca().xaxis.set_major_locator(mdates.MonthLocator(interval=1))  #設置x軸主刻度間距

plt.grid(True)
plt.show()
plt.xticks(rotation=-15)

其中,文件 data.txt中的数据为:
Date,Data
2016-12-30,1.05550

2016-12-28,1.04610

2016-12-29,1.05275

2016-12-27,1.05015

2016-12-23,1.05005

运行程序:
在这里插入图片描述

可以发现 因为时间戳 是没有按照时间先后次序排列(乱序的),因此时间折线图的序列是错乱的,为了改变这种情况,我们需要对时间序列和对应的数据进行相应的排序:

修改后的程序

在这里插入代码片# -*- coding: utf-8 -*-
"""
Created on Mon Jul 27 17:07:11 2020
@author: redheart
"""
import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
import matplotlib.dates as mdates
import pandas as pd
df = pd.read_csv('data.txt',sep=',')#读入时间戳数据
print (df)
df = df.sort_values(by = 'Date')
timeseries = pd.to_datetime(df['Date'])
plt.plot(timeseries,df['Data'],'o-b')
# plt.gca()函數獲得當前坐標軸,然後才能設置參數或作圖,plt.plot()內部實現了這一步驟
plt.gca().xaxis.set_major_formatter(mdates.DateFormatter('%y-%m-%d %H:%M'))  #設置x軸主刻度顯示格式(日期)
# plt.gca().xaxis.set_major_locator(mdates.MonthLocator(interval=1))  #設置x軸主刻度間距

plt.grid(True)
plt.show()
plt.xticks(rotation=-15)
# 按照时间戳进行排序
#df = df.sort_values(by = 'Date')
print (df)
# 替换原始的index


可以发现在这里插入图片描述可以发现此时数据序列按照时间先后的顺序呈现了出来。
参考链接:https://cloud.tencent.com/developer/ask/195429

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值