我正在尝试使用 write_points() 将数据添加到 python 中的 influxdb 数据库。但是,write_points 的时间戳部分出现错误。我试图以多种方式定义时间戳,首先使用
info = line.split()
s_time = info[2]
i_time = "20" + s_time[6:8] + "-" + s_time[0:2] + "-" + s_time[3:5] + ' ' + s_time[9:]
fixedtime = datetime.datetime.strptime(i_time, "%Y-%m-%d %H:%M:%S")
并将时间与 influxdb 所需的所有其他部分一起添加到 JSON 我还尝试将时间戳设置为 int
inttime = int(time.time()*1000);
这给了我时代。这两个时间戳都会从我的代码中的这一行引发一个值错误
dbclient.write_points(db_point, time_precision='ms', protocol='json')
在最后一行
if isinstance(timestamp, Integral):
return timestamp # assume precision is correct if timestamp is int
if isinstance(_get_unicode(timestamp), text_type):
timestamp = parse(timestamp)
if isinstance(timestamp, datetime):
if not timestamp.tzinfo:
timestamp = UTC.localize(timestamp)
ns = (timestamp - EPOCH).total_seconds() * 1e9
if precision is None or precision == 'n':
return ns
elif precision == 'u':
return ns / 1e3
elif precision == 'ms':
return ns / 1e6
elif precision == 's':
return ns / 1e9
elif precision == 'm':
return ns / 1e9 / 60
elif precision == 'h':
return ns / 1e9 / 3600
raise ValueError(timestamp)
在 line_protocol.py
当我使用纪元时间时,整数会以某种方式转换为一个集合,因此它不会传递任何 if 语句,但我不知道为什么字符串会传递其中一个 if 语句