如何格式化此date.time变量以包含毫秒到2dp?
使用Python语言中的date.time模块,我创建了两个变量。这些内容如下:
begin = datetime.datetime.now()
end = datetime.datetime.now()然后我打印下面的变量。
time_taken = end - begin以0:00:16.664335格式打印此变量time_taken。
我想问的问题是,有没有一种简单的方法将毫秒数四舍五入为2dp?
我已经搜索过其他方法,但它们似乎过于复杂,不值得使用。
发布于 2021-07-03 23:54:42
是的,取整变量的简单方法:
{selected variable} = round({selected variable},{number of dp})`
示例:
time = 1.3454
time = round(time, 2)
print time {out put is 1.35}希望这能有所帮助。
发布于 2021-07-03 23:57:08
减去datetime对象将返回timedelta对象。它有足够的时间将microseconds存储在其中。
您可以获得该值,并将其舍入到所需的精确度。
import time
from datetime import datetime
begin = datetime.now()
time.sleep(0.005) # 5 ms
end = datetime.now()
time_taken = end - begin # this is a timedelta object
time_taken_ms = round(time_taken.total_seconds() * 1000, 2)
print(time_taken_ms)输出:
6.97发布于 2021-07-04 00:35:55
减去两个datetime的结果是一个timedelta对象,它只在内部存储天、秒和微秒,这是打印它们的值时通常显示的值。如果你想要一些不同的东西,你需要定义你自己的格式化函数。下面是一个关于毫秒的例子,你想做什么就做什么:
import datetime
import time
def format_timedelta(td):
""" Format a timedelta into this format D:H:M:SS.ss """
days = td.days
hours, remainder = divmod(td.seconds, 3600)
minutes, seconds = divmod(remainder, 60)
seconds += td.microseconds / 1e6
return (f'{days}:{hours}:{minutes}:{seconds:02.2f}' if days else
f'{hours}:{minutes}:{seconds:02.2f}')
begin = datetime.datetime.now()
time.sleep(0.123) # 123 ms
end = datetime.datetime.now()
time_taken = end - begin
print(format_timedelta(time_taken)) # -> 0:0:0.12https://stackoverflow.com/questions/68237729
复制相似问题