我有一个包含日期的固定宽度数据文件,但是当我尝试绘制数据时,日期没有在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 datetime的转换,如何进行转换?
我也直接尝试过熊猫:
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
解决方法:
如果使用包含列名而不是字符串的列表,则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)
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。