簡體   English   中英

Pandas - 月年格式的兩個日期之間的月數

[英]Pandas - Number of Months Between Two Dates in Month year format

我的日期格式為 Jan-09、Jan-18,其中 09 和 18 是年份。 我如何編碼以查找這兩天之間的月數。 我嘗試使用此代碼:

ata4['mob_try'] = ((data4.last_pymnt_date - data4.issue_date)/np.timedelta64(1, 'M')).

data4['mob'] = data4['mob_try'].astype(int)

但是有一個錯誤“-:'str'和'str'不支持的操作數類型”我該如何解決這個問題?

您可以使用datetimerelativedelta來實現這一點:

from datetime import datetime
from dateutil import relativedelta
date1 = datetime.strptime(str('Jan-09'), '%b-%y')
date2 = datetime.strptime(str('Jan-18'), '%b-%y')
r = relativedelta.relativedelta(date2, date1)

total_months = r.years*12 + r.months

print("Total months: {0}".format(total_months))

這個錯誤發生在哪一行? 如果它在第一行,可能last_pymnt_dateissue_date列仍存儲為int 在這種情況下,您必須先在每個上使用pd.to_datetime()

這個例子應該工作:

d1 = pd.to_datetime(data4.last_pymnt_date)

d2 = pd.to_datetime(data4.issue_date)

data4['mob'] = (d1 - d2) // np.timedelta64(1, 'M'))

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM