source

N초를 datetime에 추가하는 표준 방법은 무엇입니까?Python에서 시간?

factcode 2022. 9. 8. 21:48
반응형

N초를 datetime에 추가하는 표준 방법은 무엇입니까?Python에서 시간?

「」가 됩니다.datetime.timePython의를 추가하여 Python의 값을 ?11:34:593= + 3 =11:35:02★★★★★★★★★★★★★★★★★★?

다음과 같은 명백한 아이디어는 효과가 없습니다.

>>> datetime.time(11, 34, 59) + 3
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'int'
>>> datetime.time(11, 34, 59) + datetime.timedelta(0, 3)
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'datetime.timedelta'
>>> datetime.time(11, 34, 59) + datetime.time(0, 0, 3)
TypeError: unsupported operand type(s) for +: 'datetime.time' and 'datetime.time'

마지막으로 다음과 같은 함수를 작성했습니다.

def add_secs_to_time(timeval, secs_to_add):
    secs = timeval.hour * 3600 + timeval.minute * 60 + timeval.second
    secs += secs_to_add
    return datetime.time(secs // 3600, (secs % 3600) // 60, secs % 60)

하지만 더 쉬운 방법을 놓치고 있다는 생각을 떨칠 수 없다.

관련된

로 사용할 수 .datetime를 지정합니다.timedelta 날짜를 날짜를 time시간적 가치를 얻기 위해서요.

예를 들어 다음과 같습니다.

import datetime
a = datetime.datetime(100,1,1,11,34,59)
b = a + datetime.timedelta(0,3) # days, seconds, then other fields.
print(a.time())
print(b.time())

는 3초 간격으로2개의 값을 산출합니다.

11:34:59
11:35:02

또, 보다 읽기 쉬운 것을 선택할 수도 있습니다.

b = a + datetime.timedelta(seconds=3)

원하신다면요


할 수 있는 이 기능을 사용할 수 .addSecs이하에 나타냅니다.

import datetime

def addSecs(tm, secs):
    fulldate = datetime.datetime(100, 1, 1, tm.hour, tm.minute, tm.second)
    fulldate = fulldate + datetime.timedelta(seconds=secs)
    return fulldate.time()

a = datetime.datetime.now().time()
b = addSecs(a, 300)
print(a)
print(b)

출력은 다음과 같습니다.

 09:11:55.775695
 09:16:55

여기 있는 다른 사용자가 설명한 것처럼 전체 datetime 개체를 사용할 수 있습니다.

from datetime import datetime, date, time, timedelta
sometime = time(8,00) # 8am
later = (datetime.combine(date.today(), sometime) + timedelta(seconds=3)).time()

단, 완전한 datetime 객체가 필요한 이유는 설명할 가치가 있다고 생각합니다.11시에 2시간을 더하면 어떻게 될지 생각해 보세요.올바른 행동은 무엇입니까?예외예요, 11시 59분보다 큰 시간은 안 돼요?다시 감겨야 하나요?

프로그래머마다 다른 것을 기대하기 때문에 어떤 결과를 선택하든 많은 사람들을 놀라게 할 것이다.게다가 프로그래머는 처음에 테스트했을 때 정상적으로 동작하는 코드를 작성하고 나서, 나중에 예기치 않은 것을 실행해 버립니다.이는 매우 좋지 않기 때문에 timedelta 객체를 시간 객체에 추가할 수 없습니다.

몇 초 동안 기본값을 덮어쓰기 위해 명확성을 높일 수 있습니다.

>>> b = a + datetime.timedelta(seconds=3000)
>>> b
datetime.datetime(1, 1, 1, 12, 24, 59)

@Pax Diablo, @bvmou, @Arachnid @Arachnid @ @ @ @ @ 。날짜/시간을 받아들여야 한다면.외부 소스로부터의 시간 객체, 이것이 대안으로 보입니다.add_secs_to_time()★★★★

def add_secs_to_time(timeval, secs_to_add):
    dummy_date = datetime.date(1, 1, 1)
    full_datetime = datetime.datetime.combine(dummy_date, timeval)
    added_datetime = full_datetime + datetime.timedelta(seconds=secs_to_add)
    return added_datetime.time()

이 상세 코드는 다음 한 줄에 압축할 수 있습니다.

(datetime.datetime.combine(datetime.date(1, 1, 1), timeval) + datetime.timedelta(seconds=secs_to_add)).time()

어쨌든 코드를 명확하게 하기 위한 함수로 마무리하고 싶습니다.

는 없어요.datetime어떤 단위가 사용되는지 불분명하기 때문입니다. 초, 시간, 주...

timedelta날짜 및 시간을 사용한 조작 클래스입니다. datetimedatetimetimedelta,datetime ★★★timedeltadatetime, 2개, 1개datetime는 2개의 2개의 2개의 2개의 2개의 2개의 2개의 2개의 2개의 2개의 2개의 의 2개의 2개의 2개의 3개의 2개의 2개의 2개의 2개의 2개의 2개의 timedelta할 수 있다.

만들다timedelta오브젝트 추가 및 추가 시간(초)datetime오브젝트:

>>> from datetime import datetime, timedelta
>>> t = datetime.now() + timedelta(seconds=3000)
>>> print(t)
datetime.datetime(2018, 1, 17, 21, 47, 13, 90244)

C++에는 다음과 같은 개념이 있습니다.std::chrono::duration.

프로젝트에 다른 파일/의존 관계를 추가할 필요가 있는 경우, 저는 방금 다음과 같은 작은 클래스를 작성했습니다.datetime.time산수를 할 수 있는 능력을 가지고 있습니다.자정이 넘으면 0이 됩니다."몇 시, 24시간 후"에는 서머타임, 윤초, 시간대 이력 변경 등 수많은 코너 케이스가 있습니다.하지만 가끔은 정말 간단한 케이스가 필요할 때도 있고, 그렇게 될 수도 있어요.

예시는 다음과 같습니다.

>>> import datetime
>>> import nptime
>>> nptime.nptime(11, 34, 59) + datetime.timedelta(0, 3)
nptime(11, 35, 2)

nptime에서 상속하다.datetime.time그 때문에, 어느 쪽의 방법도 사용할 수 있을 것입니다.

PyPi에서 다음과 같이 사용할 수 있습니다.nptime("유아 이외의 시간") 또는 GitHub: https://github.com/tgs/nptime

완성도를 높이기 위해 (Python의 경우 더 나은 날짜와 시간)을 사용하는 방법은 다음과 같습니다.

sometime = arrow.now()
abitlater = sometime.shift(seconds=3)

실제 환경에서는, 이것만으로 작업하는 것은 결코 좋은 생각이 아닙니다.time, 항상 사용datetime, 더 좋은utc밤샘, 서머타임, 사용자와 서버 간의 다른 시간대 등의 경합을 피하기 위해서입니다.

따라서 다음과 같은 접근방식을 권장합니다.

import datetime as dt

_now = dt.datetime.now()  # or dt.datetime.now(dt.timezone.utc)
_in_5_sec = _now + dt.timedelta(seconds=5)

# get '14:39:57':
_in_5_sec.strftime('%H:%M:%S')

추가해 보세요.datetime.datetime에 대해서datetime.timedelta시간 부분만 원하는 경우time()그 결과에 대한 방법datetime.datetime이의 있음.

오래된 질문이지만, 타임존을 다루는 기능을 넣어야겠다고 생각했어요핵심 부품은 다음 단계를 통과하는 것입니다.datetime.time오브젝트tzinfo결합으로 속성화 후 사용timetz()대신time()더미 날짜/시간으로 설정합니다.이 답변은 여기 있는 다른 답변에서 부분적으로 영감을 받았습니다.

def add_timedelta_to_time(t, td):
    """Add a timedelta object to a time object using a dummy datetime.

    :param t: datetime.time object.
    :param td: datetime.timedelta object.

    :returns: datetime.time object, representing the result of t + td.

    NOTE: Using a gigantic td may result in an overflow. You've been
    warned.
    """
    # Create a dummy date object.
    dummy_date = date(year=100, month=1, day=1)

    # Combine the dummy date with the given time.
    dummy_datetime = datetime.combine(date=dummy_date, time=t, tzinfo=t.tzinfo)

    # Add the timedelta to the dummy datetime.
    new_datetime = dummy_datetime + td

    # Return the resulting time, including timezone information.
    return new_datetime.timetz()

여기 아주 테스트 클래스가 된 테스트 케이스 사용).unittest

import unittest
from datetime import datetime, timezone, timedelta, time

class AddTimedeltaToTimeTestCase(unittest.TestCase):
    """Test add_timedelta_to_time."""

    def test_wraps(self):
        t = time(hour=23, minute=59)
        td = timedelta(minutes=2)
        t_expected = time(hour=0, minute=1)
        t_actual = add_timedelta_to_time(t=t, td=td)
        self.assertEqual(t_expected, t_actual)

    def test_tz(self):
        t = time(hour=4, minute=16, tzinfo=timezone.utc)
        td = timedelta(hours=10, minutes=4)
        t_expected = time(hour=14, minute=20, tzinfo=timezone.utc)
        t_actual = add_timedelta_to_time(t=t, td=td)
        self.assertEqual(t_expected, t_actual)


if __name__ == '__main__':
    unittest.main()

timedelta 객체가 아직 없는 경우 이전 시간 객체의 속성을 사용하여 새 시간 객체를 초기화하고 필요에 따라 값을 추가하는 방법도 있습니다.

   new_time:time = time(
       hour=curr_time.hour + n_hours,
       minute=curr_time.minute + n_minutes,
       seconds=curr_time.second + n_seconds
    )

여기서 오버플로는 처리되지 않으므로 자신의 값에 대해 몇 가지 가정을 하는 경우에만 이 방법이 작동합니다.하지만 한 줄이나 두 줄 정도는 아낄 수 있을 것 같아서

언급URL : https://stackoverflow.com/questions/100210/what-is-the-standard-way-to-add-n-seconds-to-datetime-time-in-python

반응형