메뉴 건너뛰기

SAP 한국 커뮤니티

펑션 좀 도와주세요.

이종원 2007.04.10 11:51 조회 수 : 2933 추천:127

해당소스는 특정날자를 입력하면 해당날자의 시작일과 마지막 일자를 구하는 펑션입니다.


 


해당 소스 나오는데는 큰 문제는 없구요.


 


하지만 윤달이라는 개념이 있어서 삽입을 해야하는데 넣을때 마다 오류가 발생됩니다.


 


도와주세요.


 


굵은 글씨로 처리한 부분에서 에러발생합니다.


 


제가 생각을 잘못 하는건지...여기까지 초급개발자 워니였습니다.


 


 


FUNCTION z_startday_endday_output.
*"----------------------------------------------------------------------
*"*"Local interface:
*"  IMPORTING
*"     REFERENCE(INPUTDAY) TYPE  SY-DATUM
*"  EXPORTING
*"     REFERENCE(STARTDAY) TYPE  SY-DATUM
*"     REFERENCE(ENDDAY) TYPE  SY-DATUM
*"----------------------------------------------------------------------


  DATA: date_input TYPE d,
        monthcheck(2) TYPE c.


  CALL FUNCTION 'DATE_CHECK_PLAUSIBILITY'   " 날자 유효성 검사 펑션
       EXPORTING
            date                      = inputday
       EXCEPTIONS
            plausibility_check_failed = 1
            OTHERS                    = 2.
  IF sy-subrc <> 0.
     MESSAGE E001(Z01) WITH 'ERROER!!'.
  ENDIF.



  date_input = inputday.
  date_input+6(2) = '01'.
  startday = date_input.



  monthcheck = date_input+4(2).
  CASE monthcheck.
    WHEN '01'.
      date_input+4(2) = '02'.
      endday = date_input - 1.
    WHEN '02'.
      date_input+4(2) = '03'.
      endday = date_input - 1.
    WHEN '03'.
      date_input+4(2) = '04'.
      endday = date_input - 1.
    WHEN '04'.
      date_input+4(2) = '05'.
      endday = date_input - 1.
    WHEN '05'.
      date_input+4(2) = '06'.
      endday = date_input - 1.
    WHEN '06'.
      date_input+4(2) = '07'.
      endday = date_input - 1.
    WHEN '07'.
      date_input+4(2) = '08'.
      endday = date_input - 1.
    WHEN '08'.
      date_input+4(2) = '09'.
      endday = date_input - 1.
    WHEN '09'.
      date_input+4(2) = '10'.
      endday = date_input - 1.
    WHEN '10'.
      date_input+4(2) = '11'.
      endday = date_input - 1.
    WHEN '11'.
      date_input+4(2) = '12'.
      endday = date_input - 1.
    WHEN '12'.


      if date_input+0(4) mod 4 = 0 and date_input+0(4) mod 100 = 0


        or date_input+0(4) mod 400.
      date_input+4(2) = '01'.
      endday = date_input + 364.


     else.


      date_input+4(2) = '01'.
      endday = date_input + 365.


     endif.
  ENDCASE.
ENDFUNCTION.

번호 제목 글쓴이 날짜 조회 수
6370 ST04 SQL 에서 주석 다는법 아시는분 계신가요? [1] 몰트 2022.06.26 825
6369 [질문] 스텐다드 화면 별 기능 수정 방법 [3] hibernate 2022.06.23 423
6368 스탠다드와 CBO 테이블이 나뉘는 이유가 궁금합니다 [2] 아밥린이 2022.06.20 1791
6367 PERFORM 구문 자주 사용 여부 [4] dev 2022.06.14 441
6366 ABAP Trial 서버에서 SE16N 기능 여부 [2] dev 2022.06.12 343
6365 call browser [2] sapecc6 2022.06.10 481
6364 테이블 데이터 중 근사치 값 선택하기 [5] 시원한바람 2022.06.09 370
6363 SO_DOCUMENT_SEND_API1 메일 첨부파일 1개 이상 가능 여부 [3] file alarm 2022.06.09 620
6362 SO_DOCUMENT_SEND_API1 함수 사용하여 메일링 기능 사용 중 문의사항이에요! [3] file alarm 2022.06.08 316
6361 solix ITAB -> Xstring 변환중 렝스길이.. [4] 먹다망고야 2022.06.07 334
6360 달력에 공휴일 지정하려면 어떻게 해야하나요? [1] yoon123 2022.06.02 489
6359 SAPGUI 엔터 키 사용 문의 입니다. [4] 십년만에 2022.06.02 355
6358 se11의 Width of Output List 에 대해 [2] file amelia 2022.05.17 291
6357 데이터 추출 [3] 블랙 2022.04.27 552
6356 pdf file 업로드 및 출력 [2] sapecc6 2022.04.22 501
6355 Desktop Office Integration in the webgui 문의.. [2] file Zekokim 2022.04.20 460
6354 abap -> asws s3 접근 코딩... [1] sapecc6 2022.04.19 256
6353 디버깅 시 데이터 나오는데 실행시키면 안나오는 이유 [1] cpfl 2022.04.15 379
6352 ALV 변경된 LAYOUT에 저장되어 있는 필드 찾는법 [1] jini 2022.04.08 555
6351 ALV GRID 에서 값 수정 후 DUMP 에러로 GETWA_NOT_ASSIGNED 가 뜹니다. [1] file 메론쥬스 2022.04.07 563