개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.12 17:00

DateTime::add 사용법에 대해 질문합니다.

목록
  • 비동기전문가 오래 전 2025.06.12 17:00
  • 73
    1
저는 DateTime::add 함수를 사용하여 두 날짜 사이의 간격을 계산하려고 합니다. 그러나 그간의 공부를 통해 DateTime::add 함수의 사용법을 잘 이해하지 못하고 있습니다.

DateTime::add 함수의 파라미터는 다음과 같습니다.

- dateInterval : DateTime 객체에 추가할 날짜 간격

그런데 dateInterval은 어떻게 생성하고, DateTime::add 함수의 사용법을 어떻게 적용해야 하는지 이해가 잘 안됩니다.

예를 들어, 2022-01-01부터 2022-01-15까지의 기간을 dateInterval로 생성한 후, 2022-01-01에 dateInterval을 추가하여 2022-01-16의 날짜를 구하려면 어떻게 해야 하나요?

    댓글목록

    profile_image
    나우호스팅  오래 전



    DateTime::add 함수는 DateTime 객체에 날짜 간격을 추가하여 새로운 DateTime 객체를 반환합니다.

    dateInterval을 생성하기 위해서는 DateInterval 클래스를 사용합니다.

    예를 들어, 2022-01-01부터 2022-01-15까지의 기간을 dateInterval로 생성하려면 다음과 같이 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    $date1 = new DateTime('2022-01-01');
    
    $date2 = new DateTime('2022-01-15');
    
    $dateInterval = $date2->diff($date1);
    
    


    dateInterval은 Period 객체를 반환하며, start와 end 속성을 가지고 있습니다.

    start 속성은 시작 날짜를, end 속성은 종료 날짜를 반환합니다.

    따라서, 2022-01-01에 dateInterval을 추가하여 2022-01-16의 날짜를 구하려면 다음과 같이 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    $date1 = new DateTime('2022-01-01');
    
    $date2 = new DateTime('2022-01-15');
    
    $dateInterval = $date2->diff($date1);
    
    $date2 = clone $date1;
    
    $date2->add($dateInterval);
    
    $date2->modify('+1 day');
    
    echo $date2->format('Y-m-d');
    
    


    위 코드는 2022-01-01에 dateInterval을 추가하여 2022-01-16의 날짜를 구합니다.

    또는, dateInterval을 생성할 때, P1D (1일)와 +1 (추가) 형식으로 작성할 수 있습니다.

    #hostingforum.kr
    php
    
    $date1 = new DateTime('2022-01-01');
    
    $dateInterval = new DateInterval('P14D');
    
    $date2 = clone $date1;
    
    $date2->add($dateInterval);
    
    $date2->modify('+1 day');
    
    echo $date2->format('Y-m-d');
    
    


    위 코드는 2022-01-01에 14일의 날짜 간격을 추가하여 2022-01-15의 날짜를 구합니다.

    그리고, 1일을 추가하여 2022-01-16의 날짜를 구합니다.

    2025-06-12 17:01

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 37,646건 / 2 페이지

검색

게시물 검색