根据datetime列切片pandas数据帧

时间:2015-08-07 13:15:18

标签: datetime pandas slice

我有一个pandas数据框,其列为datatime,如下所示:

data.ts_placed
Out[68]: 
1         2008-02-22 15:30:40
2         2008-03-20 16:56:00
3         2008-06-14 21:26:02
4         2008-06-16 10:26:02
5         2008-06-23 20:41:03
6         2008-07-17 08:02:00
7         2008-10-13 12:47:05
8         2008-11-14 09:20:33
9         2009-02-23 11:24:18
10        2009-03-02 10:29:19

我想通过在2009年之前删除所有行来对数据帧进行切片

1 个答案:

答案 0 :(得分:9)

您可以使用简单的字符串比较来将值与年份字符串进行比较:

In [63]:
df.loc[df['date'] >= '2009']

Out[63]:
                     date
index                    
9     2009-02-23 11:24:18
10    2009-03-02 10:29:19

或使用dt属性访问年份:

In [64]:
df.loc[df['date'].dt.year >= 2009]

Out[64]:
                     date
index                    
9     2009-02-23 11:24:18
10    2009-03-02 10:29:19