熊猫 Between_time 布尔值

2024-05-07

我正在尝试创建一个列,如果行值落在时间 09:00 和 17:00 之间,该列将分配 true。

我可以使用轻松选择这些时间between_time但无法分配新列 aTrue, False.

df = df.between_time('9:00', '17:00', include_start=True, include_end=True)

该语句选择适当的行,但我无法为它们分配 True-False 值。

我一直在尝试使用np.where.

df['day'] = np.where(df.between_time('9:00', '17:00', include_start=True, include_end=True),'True','False')

除了那个np.where仅适用于布尔表达式。

我这样使用它:

df['day'] = np.where((df['dayTime'] < '09:00') & (df['dayTime'] > '17:00'),'True','False')

但只得到了False returns,因为一个值不能同时大于 17 和小于 9。

我错过了一个相对简单的步骤,无法弄清楚。帮助。


您可以执行以下操作:

df.index.isin(df.between_time('9:00', '17:00', include_start=True, include_end=True).index)

因为between方法返回一个数据帧,而不是我们可以调用的布尔数组.index就像我们对任何数据帧一样,这将返回一系列时间。然后我们可以检查我们的原始时间索引是否在我们的时间索引中between method.

这将为您提供一个在您的时间范围内的布尔值数组。我想不出另一种方法来做到这一点,但这并不意味着没有一种方法

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

熊猫 Between_time 布尔值 的相关文章

随机推荐