Datetime python вычесть дни
Для форматирования объектов date и time в обоих этих классах предусмотрен метод strftime(format) . Этот метод принимает только один параметр, указывающий на формат, в который нужно преобразовать дату или время.
Для определения формата мы можем использовать один из следующих кодов форматирования:
- %a : аббревиатура дня недели. Например, Wed — от слова Wednesday (по умолчанию используются английские наименования)
- %A : день недели полностью, например, Wednesday
- %b : аббревиатура названия месяца. Например, Oct (сокращение от October)
- %B : название месяца полностью, например, October
- %d : день месяца, дополненный нулем, например, 01
- %m : номер месяца, дополненный нулем, например, 05
- %y : год в виде 2-х чисел
- %Y : год в виде 4-х чисел
- %H : час в 24-х часовом формате, например, 13
- %I : час в 12-ти часовом формате, например, 01
- %M : минута
- %S : секунда
- %f : микросекунда
- %p : указатель AM/PM
- %c : дата и время, отформатированные под текущую локаль
- %x : дата, отформатированная под текущую локаль
- %X : время, форматированное под текущую локаль
Используем различные форматы:
from datetime import datetime now = datetime.now() print(now.strftime("%Y-%m-%d")) # 2017-05-03 print(now.strftime("%d/%m/%Y")) # 03/05/2017 print(now.strftime("%d/%m/%y")) # 03/05/17 print(now.strftime("%d %B %Y (%A)")) # 03 May 2017 (Wednesday) print(now.strftime("%d/%m/%y %I:%M")) # 03/05/17 01:36
При выводе названий месяцев и дней недели по умолчанию используются английские наименования. Если мы хотим использовать текущую локаль, то мы можем ее предварительно установить с помощью модуля locale:
from datetime import datetime import locale locale.setlocale(locale.LC_ALL, "") now = datetime.now() print(now.strftime("%d %B %Y (%A)")) # 03 Май 2017 (среда)
Сложение и вычитание дат и времени
Нередко при работе с датами возникает необходимость добавить к какой-либо дате определенный промежуток времени или, наоборот, вычесть некоторый период. И специально для таких операций в модуле datetime определен класс timedelta . Фактически этот класс определяет некоторый период времени.
Для определения промежутка времени можно использовать конструктор timedelta:
timedelta([days] [, seconds] [, microseconds] [, milliseconds] [, minutes] [, hours] [, weeks])
В конструктор мы последовательно передаем дни, секунды, микросекунды, миллисекунды, минуты, часы и недели.
Определим несколько периодов:
from datetime import timedelta three_hours = timedelta(hours=3) print(three_hours) # 3:00:00 three_hours_thirty_minutes = timedelta(hours=3, minutes=30) # 3:30:00 two_days = timedelta(2) # 2 days, 0:00:00 two_days_three_hours_thirty_minutes = timedelta(days=2, hours=3, minutes=30) # 2 days, 3:30:00
Используя timedelta, мы можем складывать или вычитать даты. Например, получим дату, которая будет через два дня:
from datetime import timedelta, datetime now = datetime.now() print(now) # 2017-05-03 17:46:44.558754 two_days = timedelta(2) in_two_days = now + two_days print(in_two_days) # 2017-05-05 17:46:44.558754
Или узнаем, сколько было времени 10 часов 15 минут назад, то есть фактически нам надо вычесть из текущего времени 10 часов и 15 минут:
from datetime import timedelta, datetime now = datetime.now() till_ten_hours_fifteen_minutes = now - timedelta(hours=10, minutes=15) print(till_ten_hours_fifteen_minutes)
Свойства timedelta
Класс timedelta имеет несколько свойств, с помощью которых мы можем получить временной промежуток:
- days : возвращает количество дней
- seconds : возвращает количество секунд
- microseconds : возвращает количество микросекунд
Кроме того, метод total_seconds() возвращает общее количество секунд, куда входят и дни, и собственно секунды, и микросекунды.
Например, узнаем какой временной период между двумя датами:
from datetime import timedelta, datetime now = datetime.now() twenty_two_may = datetime(2017, 5, 22) period = twenty_two_may - now print("<> дней <> секунд <> микросекунд".format(period.days, period.seconds, period.microseconds)) # 18 дней 17537 секунд 72765 микросекунд print("Всего: <> секунд".format(period.total_seconds())) # Всего: 1572737.072765 секунд
Сравнение дат
Также как и строки и числа, даты можно сравнивать с помощью стандартных операторов сравнения:
from datetime import datetime now = datetime.now() deadline = datetime(2017, 5, 22) if now > deadline: print("Срок сдачи проекта прошел") elif now.day == deadline.day and now.month == deadline.month and now.year == deadline.year: print("Срок сдачи проекта сегодня") else: period = deadline - now print("Осталось <> дней".format(period.days))
How to subtract a day from a date?
the documentation says that will return «A duration expressing the difference between two date, time, or datetime instances. «. how do you get the actual date of, say, 5 days ago or 5 days from now?
@jfs I think this answer is fine in regard to time zones. If you subtract a day, that might actually subtract 23 or 25 hours, but the time component will remain the same. That’s what I would expect as normal behavior. Daylight saving time (DST) makes so that 1 day is not always 24 hours.
If your Python datetime object is timezone-aware than you should be careful to avoid errors around DST transitions (or changes in UTC offset for other reasons):
from datetime import datetime, timedelta from tzlocal import get_localzone # pip install tzlocal DAY = timedelta(1) local_tz = get_localzone() # get local timezone now = datetime.now(local_tz) # get timezone-aware datetime object day_ago = local_tz.normalize(now - DAY) # exactly 24 hours ago, time may differ naive = now.replace(tzinfo=None) - DAY # same time yesterday = local_tz.localize(naive, is_dst=None) # but elapsed hours may differ
In general, day_ago and yesterday may differ if UTC offset for the local timezone has changed in the last day.
For example, daylight saving time/summer time ends on Sun 2-Nov-2014 at 02:00:00 A.M. in America/Los_Angeles timezone therefore if:
import pytz # pip install pytz local_tz = pytz.timezone('America/Los_Angeles') now = local_tz.localize(datetime(2014, 11, 2, 10), is_dst=None) # 2014-11-02 10:00:00 PST-0800
then day_ago and yesterday differ:
- day_ago is exactly 24 hours ago (relative to now ) but at 11 am, not at 10 am as now
- yesterday is yesterday at 10 am but it is 25 hours ago (relative to now ), not 24 hours.
>>> import pendulum # $ pip install pendulum >>> now = pendulum.create(2014, 11, 2, 10, tz='America/Los_Angeles') >>> day_ago = now.subtract(hours=24) # exactly 24 hours ago >>> yesterday = now.subtract(days=1) # yesterday at 10 am but it is 25 hours ago >>> (now - day_ago).in_hours() 24 >>> (now - yesterday).in_hours() 25 >>> now >>> day_ago >>> yesterday
Just to Elaborate an alternate method and a Use case for which it is helpful:
from datetime import datetime, timedelta print datetime.now() + timedelta(days=-1) # Here, I am adding a negative timedelta
- Useful in the Case, If you want to add 5 days and subtract 5 hours from current datetime. i.e. What is the Datetime 5 days from now but 5 hours less ?
from datetime import datetime, timedelta print datetime.now() + timedelta(days=5, hours=-5)
It can similarly be used with other parameters e.g. seconds, weeks etc
Also just another nice function i like to use when i want to compute i.e. first/last day of the last month or other relative timedeltas etc. .
The relativedelta function from dateutil function (a powerful extension to the datetime lib)
import datetime as dt from dateutil.relativedelta import relativedelta #get first and last day of this and last month) today = dt.date.today() first_day_this_month = dt.date(day=1, month=today.month, year=today.year) last_day_last_month = first_day_this_month - relativedelta(days=1) print (first_day_this_month, last_day_last_month) >2015-03-01 2015-02-28
Genial arrow module exists
import arrow utc = arrow.utcnow() utc_yesterday = utc.shift(days=-1) print(utc, '\n', utc_yesterday)
2017-04-06T11:17:34.431397+00:00 2017-04-05T11:17:34.431397+00:00
You can also use pandas pd.Timedelta(‘1D’) (it’s extremely flexible and you can even pass something like pd.Timedelta(‘1d 5h 9s’) for 1 day, 5 hours and 9 seconds).
A convenient thing about pandas is that its datetime objects are built on datetime.datetime , so any operation involving Python’s datetime objects work fine on pandas datetime objects and vice versa.
import pandas as pd import numpy as np from datetime import datetime, date, timedelta datetime.now() - pd.Timedelta('1d') # datetime.datetime(2023, 2, 21, 15, 35, 23, 603832) pd.Timestamp('now') - timedelta(days=1) # Timestamp('2023-02-21 15:35:23.741866') pd.Timestamp('now') - pd.Timedelta('1d') # Timestamp('2023-02-21 15:35:23.882746') pd.Timestamp('now') - np.timedelta64(1, 'D') # Timestamp('2023-02-21 15:35:24.032356') date(2022, 2, 22) - pd.Timedelta('10d') # datetime.date(2022, 2, 12)
The advantage of pandas is that you can perform vectorized operations (even if the dtype is object). You can use either of pd.Timedelta / datetime.timedelta / np.timedelta64 .
pd.Series([datetime(2023,2,22), datetime(2023,2,21), datetime(2023,2,20)]) - pd.Timedelta('1d') pd.Series([date(2023,2,22), date(2023,2,21), date(2023,2,20)]) - timedelta(days=1) pd.Series([date(2023,2,22), date(2023,2,21), date(2023,2,20)]) - np.timedelta64(1, 'D')
class myDate: def __init__(self): self.day = 0 self.month = 0 self.year = 0 ## for checking valid days month and year while (True): d = int(input("Enter The day :- ")) if (d > 31): print("Plz 1 To 30 value Enter . ") else: self.day = d break while (True): m = int(input("Enter The Month :- ")) if (m > 13): print("Plz 1 To 12 value Enter . ") else: self.month = m break while (True): y = int(input("Enter The Year :- ")) if (y > 9999 and y < 0000): print("Plz 0000 To 9999 value Enter . ") else: self.year = y break ## method for aday ands cnttract days def adayDays(self, n): ## aday days to date day nd = self.day + n print(nd) ## check days subtract from date if nd == 0: ## check if days are 7 subtracted from 7 then. if(self.year % 4 == 0): if(self.month == 3): self.day = 29 self.month -= 1 self.year = self. year else: if(self.month == 3): self.day = 28 self.month -= 1 self.year = self. year if (self.month == 5) or (self.month == 7) or (self.month == 8) or (self.month == 10) or (self.month == 12): self.day = 30 self.month -= 1 self.year = self. year elif (self.month == 2) or (self.month == 4) or (self.month == 6) or (self.month == 9) or (self.month == 11): self.day = 31 self.month -= 1 self.year = self. year elif(self.month == 1): self.month = 12 self.year -= 1 ## nd == 0 if condition over ## after subtract days to day io goes into negative then elif nd < 0 : n = abs(n)## return positive if no is negative for i in range (n,0,-1): ## if self.day == 0: if self.month == 1: self.day = 30 self.month = 12 self.year -= 1 else: self.month -= 1 if(self.month == 1) or (self.month == 3)or (self.month == 5) or (self.month == 7) or (self.month == 8) or (self.month == 10) or (self.month ==12): self.day = 30 elif(self.month == 4)or (self.month == 6) or (self.month == 9) or (self.month == 11): self.day = 29 elif(self.month == 2): if(self.year % 4 == 0): self.day == 28 else: self.day == 27 else: self.day -= 1 ## enf of elif negative days ## adaying days to DATE else: cnt = 0 while (True): if self.month == 2: # check leap year if(self.year % 4 == 0): if(nd >29): cnt = nd - 29 nd = cnt self.month += 1 else: self.day = nd break ## if not leap year then else: if(nd > 28): cnt = nd - 28 nd = cnt self.month += 1 else: self.day = nd break ## checking month other than february month elif(self.month == 1) or (self.month == 3) or (self.month == 5) or (self.month == 7) or (self.month == 8) or (self.month == 10) or (self.month == 12): if(nd > 31): cnt = nd - 31 nd = cnt if(self.month == 12): self.month = 1 self.year += 1 else: self.month += 1 else: self.day = nd break elif(self.month == 4) or (self.month == 6) or (self.month == 9) or (self.month == 11): if(nd > 30): cnt = nd - 30 nd = cnt self.month += 1 else: self.day = nd break ## end of month condition ## end of while loop ## end of else condition for adaying days def formatDate(self,frmt): if(frmt == 1): ff=str(self.day)+"-"+str(self.month)+"-"+str(self.year) elif(frmt == 2): ff=str(self.month)+"-"+str(self.day)+"-"+str(self.year) elif(frmt == 3): ff =str(self.year),"-",str(self.month),"-",str(self.day) elif(frmt == 0): print("Thanky You. ") else: print("Enter Correct Choice. ") print(ff) dt = myDate() nday = int(input("Enter No. For Aday or SUBTRACT Days :: ")) dt.adayDays(nday) print("1 : day-month-year") print("2 : month-day-year") print("3 : year-month-day") print("0 : EXIT") frmt = int (input("Enter Your Choice :: ")) dt.formatDate(frmt) enter code here
It is better to use the standard library when possible, cause it is usually maintained by a lot of people, has little errors and performs faster