在 matplotlib 中绘制熊猫日期
Posted
技术标签:
【中文标题】在 matplotlib 中绘制熊猫日期【英文标题】:Plot pandas dates in matplotlib 【发布时间】:2014-10-14 12:47:58 【问题描述】:我有一个包含日期的固定宽度数据文件,但是当我尝试绘制数据时,日期在 x 轴上显示不正确。
我的文件看起来像
2014-07-10 11:49:14.377102 45
2014-07-10 11:50:14.449150 45
2014-07-10 11:51:14.521168 21
2014-07-10 11:52:14.574241 8
2014-07-10 11:53:14.646137 11
2014-07-10 11:54:14.717688 14
等
我使用 pandas 读取文件
#! /usr/bin/env python
import pandas as pd
import matplotlib.pyplot as plt
data = pd.read_fwf('myfile.log',header=None,names=['time','amount'],widths=[27,5])
data.time = pd.to_datetime(data['time'], format='%Y-%m-%d %H:%M:%S.%f')
plt.plot(data.time,data.amount)
plt.show()
所以我想这里的问题是从 pandas 到 matplotlib 日期时间的转换,如何进行转换?
我也直接用 pandas 试过:
data.time = pd.to_datetime(data['time'], format='%Y-%m-%d %H:%M:%S.%f')
data.set_index('time') # Fails!!
data.time.plot()
但这失败了
TypeError: Empty 'Series': no numeric data to plot
【问题讨论】:
【参考方案1】:如果您使用包含列名而不是字符串的列表,data.set_index 将起作用
以下应在 x 轴上显示日期:
#! /usr/bin/env python
import pandas as pd
import matplotlib.pyplot as plt
data = pd.read_fwf('myfile.log',header=None,names=['time','amount'],widths=[27,5])
data.time = pd.to_datetime(data['time'], format='%Y-%m-%d %H:%M:%S.%f')
data.set_index(['time'],inplace=True)
data.plot()
#OR
plt.plot(data.index, data.amount)
【讨论】:
【参考方案2】:以下代码将绘制特定股票的日期和股票价格。我想要 x 轴上的日期和 y 轴上的股票价格数据。下面的代码对我有用。
将 csv 加载到 pandas 数据框中,只需将 csv 文件的所需列加载到数组中并使用
plt(column_on_x_axis, column_in_y_axis, linestyle)
当然,matplotlib.pyplot 应该包含在内。
data = pd.readcsv(your_file.csv)
date_array = data['Date']
price_array = data['Prices']
plt.plot(date_array, price_array, linestyle = 'solid')
【讨论】:
以上是关于在 matplotlib 中绘制熊猫日期的主要内容,如果未能解决你的问题,请参考以下文章