当前位置: 首页 > 面试题库 >

在matplotlib中绘制熊猫日期

厍浩广
2023-03-14
问题内容

我有一个固定宽度的数据文件,其中包含日期,但是当我尝试绘制数据时,日期无法在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

等等

我用 熊猫 读文件

#! /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()

所以我想这里的问题是从熊猫到matplotlib日期时间的转换,如何进行转换?

我也直接尝试了熊猫:

data.time = pd.to_datetime(data['time'], format='%Y-%m-%d %H:%M:%S.%f')
data.set_index('time') # Fails!!
data.time.plot()

但这失败了

TypeError:空的“ Series”:没有要绘制的数字数据


问题答案:

如果您使用包含列名而不是字符串的列表,则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)


 类似资料:
  • 我有以下代码: 输出: 还有情节。 但在绘图中使用此代码时,x轴是索引。但我想得到x轴上的日期。 如何使用测试的编号和ARI的平均值绘制日期 我想,我应该把字符串(日期)改成日期,但我不知道怎么做。 最好的

  • 问题内容: 如何获得[a,b,c]的x轴值显示? 问题答案: 您可以使用来显示xtick标签: 输出:

  • 问题内容: 有一个Pandas DataFrame: 我想绘制A和B系列vs日期。 然后我要在A系列和B系列之间的区域上应用fill_between(): 哪个输出: matplotlib是否在函数中接受pandas datetime64对象?我应该将其转换为其他日期类型吗? 问题答案: 大熊猫寄存器的转换器中,其可将数字转换的日期时间的类型(如大熊猫DatetimeIndex,和D型的numpy

  • 问题内容: 我有一个零星的日期作为索引的数据框,并且列=’id’和’num’。我想在“ id”列中将重新索引应用于数据框中的每个组。 我的样本数据集如下所示: 我预计,一旦输出用的是: 我尝试过此方法,但无济于事: 返回错误: 任何帮助将非常感激 问题答案: 可能有一种更轻松的方式来做到这一点,但这可行:

  • 我在CSV文件中有一些数据,想打印出来,但图形没有显示出来 这是CSV文件http://www.mediafire.com/file/2gtbxm5adom7m4j/pop.csv

  • 我有这种熊猫。数据框。“a”、“b”是获得“x”和“y”时的条件。 我需要绘制关于相同条件的(x,y)结肠的折线图。预期结果图为: 当然,这个图像是由以下代码手动给出的: 我的问题是,当获得一个包含条件列x和y的数据帧时,如何动态地绘制如上所述的图。 列名是固定的。但是,条件列的值是动态更改的。因此,我不能使用10、20、100、200的值。 如果我有下面的“用a和b过滤”方法,我认为问题解决了: