首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >从日期时间提取大熊猫的比较时间

从日期时间提取大熊猫的比较时间
EN

Stack Overflow用户
提问于 2018-03-17 22:20:43
回答 4查看 5.2K关注 0票数 6

我有一个DataFrame

代码语言:javascript
复制
customer_number   purchase_time         quantity
14                2007-03-01 07:06:00   10
20                2007-03-12 13:05:00   13

我试着找出上午和下午的总采购量。我将purchase_time转换为datetime

代码语言:javascript
复制
df['purchase_time'] = pd.to_datetime(df['purchase_time'])
# Baskets bought in morning.
df[df['purchase_time'] < '12:00:00']

但是,结果是原始数据集。

EN

回答 4

Stack Overflow用户

回答已采纳

发布于 2018-03-17 22:54:52

在groupby中使用布尔数组

代码语言:javascript
复制
df.groupby(df.purchase_time.dt.hour < 12).sum().rename(
    {True: 'Morning', False: 'Afternoon'})

               customer_number  quantity
purchase_time                           
Afternoon                   20        13
Morning                     14        10
票数 4
EN

Stack Overflow用户

发布于 2018-03-17 22:26:26

你可以的

代码语言:javascript
复制
df[df['purchase_time'].dt.time < pd.to_datetime('12:00:00').time()]
Out[152]: 
   customer_number       purchase_time  quantity
0               14 2007-03-01 07:06:00        10
票数 9
EN

Stack Overflow用户

发布于 2018-03-17 22:24:04

你可能不需要在这里转换,只要按词汇学来比较一下时间-

代码语言:javascript
复制
df[df['purchase_time'].str.split().str[1] < '12:00:00']

   customer_number        purchase_time  quantity
0               14  2007-03-01 07:06:00        10

虽然,为了增加一层安全性,我建议转换为timedelta并进行比较--这些比较仍然适用于字符串(熊猫奇迹般地)--

代码语言:javascript
复制
df[pd.to_timedelta(
       df['purchase_time'].str.split().str[1], errors='coerce'
) < '12:00:00']

   customer_number        purchase_time  quantity
0               14  2007-03-01 07:06:00        10
票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/49342465

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档