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