与这个问题类似,我在pandas DataFrame中有一个numpy.timedelta64
列。根据前面提到的问题的答案,有一个函数pandas.tslib.repr_timedelta64
可以很好地显示以天为单位的时间差,小时:分钟:秒。我只想将它们格式化为天和小时。
所以我现在有以下内容:
def silly_format(hours):
(days, hours) = divmod(hours, 24)
if days > 0 and hours > 0:
str_time = "{0:.0f} d, {1:.0f} h".format(days, hours)
elif days > 0:
str_time = "{0:.0f} d".format(days)
else:
str_time = "{0:.0f} h".format(hours)
return str_time
df["time"].astype("timedelta64[h]").map(silly_format)
这段代码可以输出想要的结果,但我在想是否有一个类似于datetime.strftime
的函数存在于numpy
或pandas
中,可以根据提供的格式字符串格式化numpy.timedelta64
?
我尝试进一步改进@Jeff的解决方案,但它比我的答案慢得多。这是它:
days = time_delta.astype("timedelta64[D]").astype(int)
hours = time_delta.astype("timedelta64[h]").astype(int) % 24
result = days.astype(str)
mask = (days > 0) & (hours > 0)
result[mask] = days.astype(str) + ' d, ' + hours.astype(str) + ' h'
result[(hours > 0) & ~mask] = hours.astype(str) + ' h'
result[(days > 0) & ~mask] = days.astype(str) + ' d'
pandas.tslib.repr_timedelta64
,但是是否可以去掉分钟/秒部分? - joris