对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

运行程序:
对dataframe类型 时序数据按时间(戳)先后顺序排序并作图_第1张图片

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

修改后的程序

在这里插入代码片# -*- 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


可以发现对dataframe类型 时序数据按时间(戳)先后顺序排序并作图_第2张图片可以发现此时数据序列按照时间先后的顺序呈现了出来。
参考链接:https://cloud.tencent.com/developer/ask/195429

你可能感兴趣的:(python,数据结构)