Datetime python вычесть дни

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 . Фактически этот класс определяет некоторый период времени.

Читайте также:  Проверить нажата ли кнопка мыши javascript

Для определения промежутка времени можно использовать конструктор 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

Источник

Оцените статью