使用Python下一年每个月的上个星期二的打印日期
问题描述:
如何使用Python打印下一年每个月的最后一个星期二的日期。使用Python下一年每个月的上个星期二的打印日期
例如输出的第一行是:30 /月/ 2018
我不希望有一个月的全名,仅前3个字符!
目前我已经找到了如何让明年:
import datetime
now = datetime.datetime.now()
next_year = now.year + 1
任何人都可以请帮助?
答
的calendar模块非常适合这样的:
您可以使用calendar.month_abbr这就像你想的 缩写个月的数组。
week
是一个数组,表示从星期一开始的星期几,所以星期二将是week[1]
。
import calendar
import datetime
now = datetime.datetime.now()
next_year = now.year + 1
for month in range(1, 13):
last_tuesday = max(week[1] for week in calendar.monthcalendar(next_year, month))
print('{}/{}/{}'.format(last_tuesday, calendar.month_abbr[month], next_year))
输出:
30/Jan/2018
27/Feb/2018
27/Mar/2018
24/Apr/2018
29/May/2018
26/Jun/2018
31/Jul/2018
28/Aug/2018
25/Sep/2018
30/Oct/2018
27/Nov/2018
25/Dec/2018
答
我也建议DateOffset反对LastWeekOfMonth
大熊猫。
介绍上周月份月度日期像这样
from pandas.tseries.offsets import LastWeekOfMonth
def last_tues(year):
return (pd.date_range('1/1/' + str(year), periods=12, freq='M')
- LastWeekOfMonth(n=1, weekday=1)).strftime('%d/%b/%Y'))
last_tues(2018)
Out[31]:
array(['30/Jan/2018', '27/Feb/2018', '27/Mar/2018', '24/Apr/2018',
'29/May/2018', '26/Jun/2018', '26/Jun/2018', '28/Aug/2018',
'25/Sep/2018', '30/Oct/2018', '27/Nov/2018', '25/Dec/2018'],
dtype='<U11')
感谢“每个月的最后一个星期二 ” –