计算两个日期之间的周末数(周六和周日)

Calculate the number of weekends (Saturdays and Sundays), between two dates

我有一个包含两个日期列的数据框,一个是开始日期,一个是结束日期。如何使用 pandas 或 python 日期时间

找到开始日期和结束日期之间的周末数

我知道 pandas 有 DatetimeIndex,其中 returns 从星期一开始的每一天的值都为 0 到 6

# create a data-frame
import pandas as pd
df = pd.DataFrame({'start_date':['4/5/19','4/5/19','1/5/19','28/4/19'],
                   'end_date': ['4/5/19','5/5/19','4/5/19','5/5/19']})

# convert objects to datetime format
df['start_date'] = pd.to_datetime(df['start_date'], dayfirst=True)
df['end_date'] = pd.to_datetime(df['end_date'], dayfirst=True)

# Trying to get the date index between dates as a prelim step but fails
pd.DatetimeIndex(df['end_date'] - df['start_date']).weekday

我希望结果是这样的:(weekend_count 包括开始日期和结束日期)

start_date  end_date    weekend_count
4/5/2019    4/5/2019    1
4/5/2019    5/5/2019    2
1/5/2019    4/5/2019    1
28/4/2019   5/5/2019    3

试试:

df['weekend_count']=((df.end_date-df.start_date).dt.days+1)-np.busday_count(
                     df.start_date.dt.date,df.end_date.dt.date)
print(df)

  start_date   end_date  weekend_count
0 2019-05-04 2019-05-04              1
1 2019-05-04 2019-05-05              2
2 2019-05-01 2019-05-04              1
3 2019-04-28 2019-05-05              3

IIUC

df['New']=[pd.date_range(x,y).weekday.isin([5,6]).sum() for x , y in zip(df.start_date,df.end_date)]
df
  start_date   end_date  New
0 2019-05-04 2019-05-04    1
1 2019-05-04 2019-05-05    2
2 2019-05-01 2019-05-04    1
3 2019-04-28 2019-05-05    3