第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機(jī)立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

獲取 DataFrame 中的前一個工作日

獲取 DataFrame 中的前一個工作日

哈士奇WWW 2021-07-01 13:19:39
我有一個包含兩列、日期和類別的 DataFrame。我想根據(jù)規(guī)則創(chuàng)建一個新的日期列:如果類別是B那么值應(yīng)該是最接近日期的工作日(僅來自過去或當(dāng)天本身),否則它是日期列本身的值。我將工作日定義為不在周末的任何一天,也不出現(xiàn)在holidays下面最小示例中定義的列表中。請考慮以下 DataFrame df:import datetime as dtimport pandas as pdfrom IPython.display import displayholidays = [dt.datetime(2018, 10, 11)]df = pd.DataFrame({"day": ["2018-10-10", "2018-10-11", "2018-10-12",                       "2018-10-13", "2018-10-14", "2018-10-15"                      ],               "category":["A", "B", "C", "B", "C", "A"]              })df["day"] = pd.to_datetime(df.day, format="%Y-%m-%d")display(df)         day category0 2018-10-10        A1 2018-10-11        B2 2018-10-12        C3 2018-10-13        B4 2018-10-14        C5 2018-10-15        A如何獲得第三列,其值為下面列出的值?2018-10-102018-10-102018-10-122018-10-122018-10-142018-10-15我創(chuàng)建了一個函數(shù),可以在處理列表時查找最后一個工作日,如果有幫助的話。# creates a list whose elements are all days in the years 2017, 2018 and 2019days = [dt.datetime(2017, 1 , 1) + dt.timedelta(k) for k in range(365*3)]def lastt_bus_day(date):    return max(        [d for d in days if d.weekday() not in [5, 6]                            and d not in holidays                            and d <= date        ]    )for d in df.day:    print(last_bus_day(d))#prints2018-10-10 00:00:002018-10-10 00:00:002018-10-12 00:00:002018-10-12 00:00:002018-10-12 00:00:002018-10-15 00:00:00
查看完整描述

3 回答

?
躍然一笑

TA貢獻(xiàn)1826條經(jīng)驗(yàn) 獲得超6個贊

Pandas 支持通過自定義工作日提供您自己的假期。


該解決方案的好處是無縫支持相鄰的假期;例如,某些地區(qū)的節(jié)禮日和圣誕節(jié)。


# define custom business days

weekmask = 'Mon Tue Wed Thu Fri'

holidays = ['2018-10-11']


bday = pd.tseries.offsets.CustomBusinessDay(holidays=holidays, weekmask=weekmask)


# construct mask to identify when days must be sutracted

m1 = df['category'] == 'B'

m2 = df['day'].dt.weekday.isin([5, 6]) | df['day'].isin(holidays)


# apply conditional logic

df['day'] = np.where(m1 & m2, df['day'] - bday, df['day'])


print(df)


  category        day

0        A 2018-10-10

1        B 2018-10-10

2        C 2018-10-12

3        B 2018-10-12

4        C 2018-10-14

5        A 2018-10-15

編輯:根據(jù)您的評論,“我剛剛意識到我沒有問清楚我想要什么。我想找到前一個工作日”,您可以簡單地使用:


df['day'] -= bday


查看完整回答
反對 回復(fù) 2021-07-13
  • 3 回答
  • 0 關(guān)注
  • 337 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號