我试图使用" plot_date"制作一个简单的XY图。通过加载具有两个日期和值的文件,但尚未取得成功。我们的想法是让第0列和第1列表示" time1",将第2列和第3列表示为" time2",将第4列表示为" val"。
数据输入数据如下所示:
2017-04-08 16:54:37 2017-04-08 16:55:08 1
2017-04-08 16:58:28 2017-04-08 16:58:33 1
2017-04-08 17:02:18 2017-04-08 17:02:24 1
代码
import matplotlib.pyplot as plt
from matplotlib.dates import strpdate2num
import numpy as np
import matplotlib.colors
import matplotlib.cm
from matplotlib.dates import date2num, DateFormatter
import datetime as dt
time1,time2,val = np.loadtxt(inputfile, usecols=(0,1,2,3,4), unpack=True, converters = {0,1: strpdate2num("%Y-%m-%d %H:%M:%S")})
我在这里收到错误:
>>> time1,time2,val = np.loadtxt(inputfile, usecols=(0,1,2,3,4), unpack=True, converters = {0,1: strpdate2num("%Y-%m-%d %H:%M:%S")})
File "<stdin>", line 1
time1,time2,val = np.loadtxt(inputfile, usecols=(0,1,2,3,4), unpack=True, converters = {0,1: strpdate2num("%Y-%m-%d %H:%M:%S")})
^
SyntaxError: invalid syntax
关于我可能做错的任何想法?关于如何纠正的建议?
除此之外,我希望从time1中减去time2并获得秒数的差异。这可能吗?
最后,我想绘制变量,类似于:
fig, ax = plt.subplots()
ax.plot_date(time1, val, 'b-', color='b')
ax.plot_date(time2, val, 'b-', color='g')
答案 0 :(得分:2)
您必须单独转换每个列,然后将其合并:
e.openFile();