亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

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

如何在python中按遞增順序將NAT中丟失的日期替換為某個日期

如何在python中按遞增順序將NAT中丟失的日期替換為某個日期

RISEBY 2021-12-09 15:23:28
我有一個日期列缺失值(python 中的 NAT)需要在 1/1/2015、1/2/2016、1/3/2016 的一天內循環遞增誰能幫我嗎 ?
查看完整描述

1 回答

?
狐的傳說

TA貢獻1804條經驗 獲得超3個贊

這將為您的數據框添加增量日期。


import pandas as pd

import datetime as dt


ddict = {

    'Date': ['2014-12-29','2014-12-30','2014-12-31','','','','',]

    }


data = pd.DataFrame(ddict)

data['Date'] = pd.to_datetime(data['Date'])


def fill_dates(data_frame, date_col='Date'):

    ### Seconds in a day (3600 seconds per hour x 24 hours per day)

    day_s = 3600 * 24


    ### Create datetime variable for adding 1 day

    _day = dt.timedelta(seconds=day_s)


    ### Get the max non-null date

    max_dt = data_frame[date_col].max()


    ### Get index of missing date values

    NaT_index = data_frame[data_frame[date_col].isnull()].index


    ### Loop through index; Set incremental date value; Increment variable by 1 day

    for i in NaT_index:

        data_frame[date_col][i] = max_dt + _day

        _day += dt.timedelta(seconds=day_s)


### Execute function

fill_dates(data, 'Date')

初始數據幀:


        Date

0 2014-12-29

1 2014-12-30

2 2014-12-31

3        NaT

4        NaT

5        NaT

6        NaT

運行函數后:


        Date

0 2014-12-29

1 2014-12-30

2 2014-12-31

3 2015-01-01

4 2015-01-02

5 2015-01-03

6 2015-01-04


查看完整回答
反對 回復 2021-12-09
  • 1 回答
  • 0 關注
  • 198 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號