0

我对 Python 很陌生,有一个问题。目前我正在使用它来计算消息发出和消息进入之间的时间。然后将生成的开始时间、时间增量和唯一 ID 呈现在文件中。同样,我正在使用 Python 2.7.2

目前它减去两次,结果是 0.002677777777(0.00 是小时和分钟),我不需要。如何格式化它以使其以秒 (59.178533,00) 开头,59 为秒。同样,有时 python 会将数字显示为 8.9999999 x e-05。我怎样才能强制它始终显示确切的数字。

def time_deltas(infile): 
   entries = (line.split() for line in open(INFILE, "r")) 
   ts = {}  
   for e in entries: 
      if " ".join(e[2:5]) == "OuchMsg out: [O]": 
         ts[e[8]] = e[0]    
      elif " ".join(e[2:5]) == "OuchMsg in: [A]":    
         in_ts, ref_id = e[0], e[7] 
         out_ts = ts.pop(ref_id, None)    
         yield (float(out_ts),ref_id[1:-1], float(in_ts) - float(out_ts))

INFILE = 'C:/Users/klee/Documents/Ouch20111130_cartprop04.txt'
import csv

with open('output_file.csv', 'w') as f: 
   csv.writer(f).writerows(time_deltas(INFILE))

这是数据的一个小样本:

61336.206267 - OuchMsg out: [O] enter order. RefID [F25Q282588] OrdID [X1F3500687  ]
4

2 回答 2

2

如果float(out_ts)是小时,那么'{0:.3f}'.format(float(out_ts) * 3600.)将为您提供秒的文本表示,小数点后三位数字。

于 2011-12-01T14:31:19.407 回答
1

我怎样才能强制它始终显示确切的数字。

这有时是不可能的,因为浮点数不准确

另一方面,您可以根据需要格式化浮动。有关说明,请参见此处

EG:将您的yield行替换为:

yield ("%.5f"%float(out_ts),"%.5f"%ref_id[1:-1], "%.5f"%(float(in_ts) - float(out_ts)))

将逗号后的所有值截断为 5 位。对于许多不同的格式,还有其他格式选项。

于 2011-12-01T14:30:26.477 回答