我读入一个文件并用熊猫DataFrame
绘制它。索引是DatetimeIndex,然后我使用ginput(1)
方法得到一个点,但是我得到的坐标是错误的。Ginput给datetimeindex输入错误的日期
的代码如下:
import pandas as pd
from matplotlib.dates import num2date, date2num
ts = pd.date_range('2012-04-12,16:13:09', '2012-04-14,00:13:09', freq='H')
df = pd.DataFrame(index=ts)
df[0] = 20.6
我然后情节和使用ginput在图表上点击:
df.plot()
t = pylab.ginput(n=1) #click somewhere near 13-APR-2012
然而,第一项似乎是一个浮子
In [8]: x = t[0][0] # ~ 370631.67741935479
In [9]: num2date(x)
Out[9]: datetime.datetime(1015, 10, 3, 16, 15, 29, 32253, tzinfo=<matplotlib.dates._UTC object at 0x104196550>)
# this is way out!
该文件表明它应该使用这些浮标(来自datetonum
):
In [10]: dt = pd.to_datetime('13-4-2012', dayfirst=True)
In [11]: date2num(dt)
Out[11]: 734606.0
这是什么浮点数,以及如何将它转换为日期时间?
注:如果我从数据框中删除行的一个这种正常工作:
df1 = df.drop(ts[1], axis=0)
...
我在[github](https: //github.com/pydata/pandas/issues/2503)。 –
非常感谢你的帮助。你的编辑是完美的:) – wuwucat