如何检查两个日期是否介于代表开始日期和结束日期的数据框的两列之间 [英] How to check if two dates falls between two columns of dataframe representing start date and end date

查看:65
本文介绍了如何检查两个日期是否介于代表开始日期和结束日期的数据框的两列之间的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我正在尝试检查我的开始日期和结束日期是否在数据框中的给定StartDate和EndDate之间

I am trying to check if my start date and end date falls between the given StartDate and EndDate in my dataframe

DataFrame看起来像

DataFrame looks like

TermYear Term   StartDate      EndDate
 2017     1     2017-01-10    2017-03-31
 2017     2     2017-04-10    2017-06-30
 2017     3     2017-07-24    2017-09-18
 2017     4     2017-09-30    2017-12-04

我正在尝试获取给定日期即

I am trying to fetch the term and TermYear when my given date i.e.

Start Date: '2017-01-24'
End Date: '2017-09-29'

在数据帧的开始日期和结束日期之间,应该获取多个行有什么想法吗?我尝试过

Lies between start and end date of dataframe it should fetch multiple rows any ideas? I have tried

lowerDate = np.datetime64('2017-07-24')
upperDate = np.datetime64('2017-07-26')
termDates = termDates[(termDates.StartDate >= lowerDate) &
                      (termDates.EndDate <= upperDate) ][['Term', 'TermYear']]

但是它返回了空的数据框

But it returns me empty dataframe

预期输出:

Term    TermYear
 2017     1     
 2017     2     
 2017     3     

推荐答案

使用

In [1820]: df[(df.StartDate <= StartDate) & (df.EndDate >= EndDate)]
Out[1820]:
   TermYear  Term   StartDate     EndDate
2      2017     3  2017-07-24  2017-09-18

对于特定列

In [1826]: df.loc[(df.StartDate<=StartDate) & (df.EndDate>=EndDate), ['Term', 'TermYear']]
Out[1826]:
   Term  TermYear
2     3      2017

在哪里

In [1821]: df
Out[1821]:
   TermYear  Term   StartDate     EndDate
0      2017     1  2017-01-10  2017-03-31
1      2017     2  2017-04-10  2017-06-30
2      2017     3  2017-07-24  2017-09-18
3      2017     4  2017-09-30  2017-12-04

In [1822]: StartDate
Out[1822]: '2017-07-24'

In [1823]: EndDate
Out[1823]: '2017-08-29'

In [1835]: df.dtypes
Out[1835]:
TermYear              int64
Term                  int64
StartDate    datetime64[ns]
EndDate      datetime64[ns]
dtype: object

这篇关于如何检查两个日期是否介于代表开始日期和结束日期的数据框的两列之间的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
相关文章
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆