python - Pandas 和 Matplotlib - fill_between() 与 datetime64

标签 python pandas matplotlib

有一个 Pandas 数据框:

<class 'pandas.core.frame.DataFrame'>
Int64Index: 300 entries, 5220 to 5519
Data columns (total 3 columns):
Date             300 non-null datetime64[ns]
A                300 non-null float64
B                300 non-null float64
dtypes: datetime64[ns](1), float64(2)
memory usage: 30.5 KB

我想绘制 A 和 B 系列与日期。

plt.plot_date(data['Date'], data['A'], '-')
plt.plot_date(data['Date'], data['B'], '-')

然后我想在 A 和 B 系列之间的区域应用 fill_between():

plt.fill_between(data['Date'], data['A'], data['B'],
                where=data['A'] >= data['B'],
                facecolor='green', alpha=0.2, interpolate=True)

哪些输出:

TypeError: ufunc 'isfinite' not supported for the input types, and the inputs
could not be safely coerced to any supported types according to the casting 
rule ''safe''

matplotlib 是否在 fill_between() 函数中接受 pandas datetime64 对象?我应该将其转换为不同的日期类型吗?

最佳答案

Pandas registers a convertermatplotlib.units.registry 中,它将许多日期时间类型(例如 pandas DatetimeIndex 和 dtype datetime64 的 numpy 数组)转换为 matplotlib datenums,但它不处理 Pandas Series 与 dtype datetime64

In [67]: import pandas.tseries.converter as converter

In [68]: c = converter.DatetimeConverter()

In [69]: type(c.convert(df['Date'].values, None, None))
Out[69]: numpy.ndarray              # converted (good)

In [70]: type(c.convert(df['Date'], None, None))
Out[70]: pandas.core.series.Series  # left unchanged

fill_between 检查并使用转换器来处理数据(如果存在)。

因此,作为一种解决方法,您可以将日期转换为 datetime64 的 NumPy 数组:

d = data['Date'].values
plt.fill_between(d, data['A'], data['B'],
                where=data['A'] >= data['B'],
                facecolor='green', alpha=0.2, interpolate=True)

例如,

import numpy as np
import matplotlib.pyplot as plt
import pandas as pd

N = 300
dates = pd.date_range('2000-1-1', periods=N, freq='D')
x = np.linspace(0, 2*np.pi, N)
data = pd.DataFrame({'A': np.sin(x), 'B': np.cos(x),
               'Date': dates})
plt.plot_date(data['Date'], data['A'], '-')
plt.plot_date(data['Date'], data['B'], '-')

d = data['Date'].values
plt.fill_between(d, data['A'], data['B'],
                where=data['A'] >= data['B'],
                facecolor='green', alpha=0.2, interpolate=True)
plt.xticks(rotation=25)
plt.show()

enter image description here

关于python - Pandas 和 Matplotlib - fill_between() 与 datetime64,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29329725/

相关文章:

python - Numpy 数组占用太多内存

python - 使用 Pandas 计算重复项之间的交集

python - 从列中获取字符串的第一个字母

python - 带有值的堆叠条形图

python - Python 装饰器中的语法错误

python - 在 Python 中使用 rm -rf 的最简单方法

python - 如何使用元组填充数据框?

python - 为什么 matplotlib 中显示两条线?

python - 如何在 Django Web 应用程序中渲染 Matplotlib 绘图?

如果列值不为 NULL,则 Python pandas 应用函数