Frage

Wie können Sie den folgenden Freitag um 03.00 Uhr als datetime Objekt berechnen?

Zur Verdeutlichung:. das heißt, soll das berechnete Datum immer größer sein als 7 Tage entfernt, und weniger als oder gleich 14

War es hilfreich?

Lösung

Hier ist eine Funktion und ein Test, dass es die Anforderungen des OP erfüllt:

import datetime

_3AM = datetime.time(hour=3)
_FRI = 4 # Monday=0 for weekday()

def next_friday_3am(now):
    now += datetime.timedelta(days=7)
    if now.time() < _3AM:
        now = now.combine(now.date(),_3AM)
    else:
        now = now.combine(now.date(),_3AM) + datetime.timedelta(days=1)
    return now + datetime.timedelta((_FRI - now.weekday()) % 7)

if __name__ == '__main__':
    start = datetime.datetime.now()
    for i in xrange(7*24*60*60):
        now = start + datetime.timedelta(seconds=i)
        then = next_friday_3am(now)
        assert datetime.timedelta(days=7) < then - now <= datetime.timedelta(days=14)
        assert then.weekday() == _FRI
        assert then.time() == _3AM

Andere Tipps

Wenn Sie dateutil installieren, dann könnte man so etwas tun:

import datetime
import dateutil.relativedelta as reldate

def following_friday(dt):   
    rd=reldate.relativedelta(
        weekday=reldate.FR(+2),
        hours=+21)
    rd2=reldate.relativedelta(
        hour=3,minute=0,second=0,microsecond=0)
    return dt+rd+rd2

Oben, sagt hours=+21 relativedelta die dt von 21 Stunden zu erhöhen, bevor Sie den nächsten Freitag zu finden. Also, wenn dt ist der 12. März 2010 um 02.00 Uhr, das Hinzufügen 21 Stunden macht es 11.00 Uhr am selben Tag , aber wenn dt nach 03.00 Uhr ist, dann Zugabe von 21 Stunden pushs dt in Samstag.

Hier finden Sie einige Test-Code.

if __name__=='__main__':
    today=datetime.datetime.now()
    for dt in [today+datetime.timedelta(days=i) for i in range(-7,8)]:
        print('%s --> %s'%(dt,following_friday(dt)))

, die ergibt:

2010-03-05 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-06 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-07 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-08 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-09 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-10 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-11 20:42:09.246124 --> 2010-03-19 03:00:00
2010-03-12 20:42:09.246124 --> 2010-03-26 03:00:00 
2010-03-13 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-14 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-15 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-16 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-17 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-18 20:42:09.246124 --> 2010-03-26 03:00:00
2010-03-19 20:42:09.246124 --> 2010-04-02 03:00:00

, während vor 03.00:

two = datetime.datetime(2010, 3, 12, 2, 0)
for date in [two+datetime.timedelta(days=i) for i in range(-7,8)]:
    result = following_friday(date)
    print('{0}-->{1}'.format(date,result))

ergibt:

2010-03-05 02:00:00-->2010-03-12 03:00:00
2010-03-06 02:00:00-->2010-03-19 03:00:00
2010-03-07 02:00:00-->2010-03-19 03:00:00
2010-03-08 02:00:00-->2010-03-19 03:00:00
2010-03-09 02:00:00-->2010-03-19 03:00:00
2010-03-10 02:00:00-->2010-03-19 03:00:00
2010-03-11 02:00:00-->2010-03-19 03:00:00
2010-03-12 02:00:00-->2010-03-19 03:00:00
2010-03-13 02:00:00-->2010-03-26 03:00:00
2010-03-14 02:00:00-->2010-03-26 03:00:00
2010-03-15 02:00:00-->2010-03-26 03:00:00
2010-03-16 02:00:00-->2010-03-26 03:00:00
2010-03-17 02:00:00-->2010-03-26 03:00:00
2010-03-18 02:00:00-->2010-03-26 03:00:00
2010-03-19 02:00:00-->2010-03-26 03:00:00

Ich mag dateutil für solche Aufgaben im Allgemeinen, aber ich verstehe nicht, die Heuristik Sie wollen - wie ich die Worte verwenden, wenn ich „nächster freitag“ sagen und es sich Donnerstag I würde mittlere morgen (wahrscheinlich zu hart arbeiten und den Überblick verloren, was Tag der Woche ich habe es) . Wenn Sie Ihre Heuristik rigoros können sie sicher programmiert werden, natürlich, aber wenn sie es komisch und schrullig genug, um Sie sind unwahrscheinlich sie bereits angeben finden Sie in vorhandenen Pakete vorprogrammiert; -).

Auf der Basis Ihrer Klarstellung ... Ich glaube, Sie so etwas tun kann:

from datetime import *
>>> today = datetime.today()
>>> todayAtThreeAm = datetime(today.year, today.month, today.day, 3)
>>> todayAtThreeAm
datetime.datetime(2010, 3, 12, 3, 0)
>>> nextFridayAtThreeAm = todayAtThreeAm + timedelta(12 - today.isoweekday())
>>> nextFridayAtThreeAm
datetime.datetime(2010, 3, 19, 3, 0)

isoweekday() Hinweis Erträge 1 bis 7 für Montag bis Sonntag. 12 stellt Freitag der folgenden Woche. So 12 -. Today.isoweekday () gibt Ihnen die richtige Zeit Delta Sie müssen heute hinzufügen

Hope, das hilft.

Mit Pendel , können Sie tun:

In [15]: pendulum.now().next(pendulum.FRIDAY).next(pendulum.FRIDAY).add(hours=3)
Out[15]: DateTime(2019, 5, 3, 3, 0, 0, tzinfo=Timezone('America/Los_Angeles'))

Beachten Sie, dass es zwei next Friday in dieser Zeile.

Um es in String zu konvertieren,

In [16]: pendulum.now().next(pendulum.FRIDAY).next(pendulum.FRIDAY).add(hours=3).to_iso8601_string()
Out[16]: '2019-05-03T03:00:00-07:00'
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top