Обходной путь для отметки даты и времени () в окнах для дат, предшествующих 1970-01-01 - PullRequest
0 голосов
/ 01 февраля 2019

В настоящее время я пытаюсь создать числовые объекты в наборе данных путем преобразования дат в метки времени.Если он работает на Mac, он работает безупречно, в Windows он выдает

OS Error: [Errno 22] Invalid argument

, что, вероятно, связано с тем, что windows не поддерживает временные метки unix до 1970-01-01 .У меня даты с 1955 года.Вот мой код:

import time
import datetime

current_timestamp = time.time()
df.loc[:, "FEATURE_num"] = df["FEATURE"].apply(lambda d: datetime.datetime.strptime(d, '%Y-%m-%d').timestamp() if isinstance(d, str) else current_timestamp)

Я где-то видел, возможно, предложил использовать datetime.timedelta(), но я не мог понять, как его интегрировать.

1 Ответ

0 голосов
/ 01 февраля 2019

Вы можете сделать это (неявно), используя datetime.timedelta, чтобы вычислить «григорианскую» временную метку, которая будет действительна для дат с 1582 по 15 октября по настоящее время (или некоторой другой «эпохи»)вы хотели бы использовать).

from datetime import datetime


GREGORIAN_EPOCH = datetime.strptime('1582-10-15', '%Y-%m-%d')


def gregorian_timestamp(date, format='%Y-%m-%d'):
    """ Calculate timestamp using start of Gregorian calender as epoch.

        The date parameter can be either be a string or a datetime.datetime
        object. Strings will be parsed using the '%Y-%m-%d' format by default
        unless a different one is specfied via the optional format parameter.
    """
    try:
        date = datetime.strptime(date, format)
    except TypeError:
        pass
    return (date - GREGORIAN_EPOCH).total_seconds()  # The timedelta in seconds.


if __name__ == '__main__':

    current_date = datetime.now()
    timestamp = gregorian_timestamp(current_date)
    print('gregorian timestamp:', timestamp)  # -> gregorian timestamp: 13768250461.136208

    timestamp = gregorian_timestamp('1970-01-01')
    print('gregorian timestamp:', timestamp)  # -> gregorian timestamp: 12219292800.0

    timestamp = gregorian_timestamp('1955-02-28')
    print('gregorian timestamp:', timestamp)  # -> gregorian timestamp: 11750918400.0

    timestamp = gregorian_timestamp('1582-10-15')
    print('gregorian timestamp:', timestamp)  # -> gregorian timestamp: 0.0
...