我有一些数据,看起来像这样:如何在x-y轴上使用日期和时间绘制轮廓图?
#date time temp press rh
09/10/2011 07:50 11.4 798.1 14.1
09/10/2011 08:00 11.9 798.3 13.6
...
09/10/2011 11:30 FALSE FALSE FALSE
09/10/2011 11:40 25.4 798.3 11.2
09/10/2011 11:50 23.2 799.1 11.2
.....
我想这样做“临时”的等高线图与y轴在x轴上的“时间”和“日期”。
我试过用大熊猫来处理日期和NaN
值更好。
data=np.genfromtxt("dataFile.txt", comments="#", dtype='str')
header_names=['date', 'time', 'temp', 'press', 'rh']
df = pd.DataFrame(data, dtype=None, columns=header_names)
df['date']=pd.to_datetime(df['date'], format='%d/%m/%Y').dt.date
df.time=pd.to_datetime(df.time, format='%H:%M').dt.time
df.temp = pd.to_numeric(df.temp, errors='coerse')
....
dfMesh=df.pivot('date', 'time', 'temp')
X=dfMesh.columns.values
Y=dfMesh.index.values
Z=dfMesh.values
x,y=np.meshgrid(X, Y)
plt.contourf(x, y, Z)
,但我得到了以下错误:
Traceback (most recent call last): File "./contourPlot_pandas.py", line 33, in x,y=np.meshgrid(X, Y) File "/Users/marybau/anaconda/lib/python3.6/site-packages/numpy/lib/function_base.py", line 4533, in meshgrid return [x * mult_fact for x in output] File "/Users/marybau/anaconda/lib/python3.6/site-packages/numpy/lib/function_base.py", line 4533, in return [x * mult_fact for x in output] TypeError: unsupported operand type(s) for *: 'datetime.time' and 'int
'
我自己也尝试其他不同的方式来做到这一点,而无需使用熊猫,但我最终因类似的问题date-time
格式或NaN
。有什么建议么?谢谢!