메뉴 건너뛰기

SAP 한국 커뮤니티



ABAP 소스코드 다운로드 프로그램

라띠 2011.10.05 10:34 조회 수 : 20065

ABAP 소스코드 다운로드 프로그램입니다

 

*=============================================================
* Program: ZZTFD325
* Author: Tim Dempsey, PBS Consulting Inc. (DEMPSEYT@EROLS.COM)
* Date: November 1997
* Application: Basis
* Sub-Application: Download ABAP programs *
*----------------------------------------------------------------
REPORT (SY-REPID) NO STANDARD PAGE HEADING LINE-SIZE 132 LINE-COUNT 55.

TABLES:TRDIR.

SELECT-OPTIONS: PGMNAME FOR TRDIR-NAME.

CONSTANTS: LINESIZE value 2048.
PARAMETERS: HEADING AS CHECKBOX DEFAULT 'X',
            FGROUP AS CHECKBOX,
            USER LIKE TRDIR-CNAM DEFAULT '*',
            DOWNLOAD AS CHECKBOX default 'X',
            pa_TEXTP AS CHECKBOX,
            DOWNDIR(80) DEFAULT 'C:temp',
            chg_date(8) default '20000101',
            chg_time(6) default '000000'.
* ,
* PGMNAME like TRDIR-NAME.

DATA: W_TEXT(128), W_FILENAME(128), W_PROGRAM_LOW(8), W_PROGRAM_HIGH(8).

DATA: * _texttab type textpool,
texttab type standard table of textpool initial size 0 with header line,
* BEGIN OF TEXTTAB OCCURS 0,
* ID(1),
* KEY(8),
* ENTRY(70),
* END OF TEXTTAB,

BEGIN OF ABAPTAB OCCURS 500,
* LINE(72),
    line(LINESIZE),
END OF ABAPTAB,

BEGIN OF TRTAB OCCURS 0,
    NAME LIKE TRDIR-NAME,
    ENTRY LIKE TEXTTAB-ENTRY,
    CDAT LIKE TRDIR-CDAT,
    UDAT LIKE TRDIR-UDAT,
END OF TRTAB,

BEGIN OF TRFTAB OCCURS 0,
    NAME LIKE TRDIR-NAME,
    ENTRY LIKE TEXTTAB-ENTRY,
    CDAT LIKE TRDIR-CDAT,
    UDAT LIKE TRDIR-UDAT,
END OF TRFTAB.

START-OF-SELECTION.
 
  IF FGROUP = ' '.
    PERFORM LOAD_TRDIR_PROGRAM.
    PERFORM PROCESS_PROGRAM.
  ELSE.
    PERFORM LOAD_TRDIR_FGROUP.
    PERFORM PROCESS_FGROUP.
  ENDIF.
 
*&---------------------------------------------------------------------*
*& form load_trdir_program.
*&---------------------------------------------------------------------*
FORM LOAD_TRDIR_PROGRAM.
  SELECT * FROM TRDIR
         WHERE NAME IN PGMNAME
           and sdate >= chg_date
           and stime >= chg_time.

    IF USER <> '*'.
      CHECK TRDIR-UNAM = USER OR TRDIR-CNAM = USER. 
    ENDIF.

    CLEAR: TEXTTAB.
    REFRESH: TEXTTAB.
    CLEAR: TRTAB.

    READ TEXTPOOL TRDIR-NAME INTO TEXTTAB LANGUAGE 'E'.
    IF SY-SUBRC = 0.
      READ TABLE TEXTTAB WITH KEY 'R'.
      MOVE TEXTTAB-ENTRY TO TRTAB-ENTRY.
    ENDIF.

    MOVE TRDIR-NAME TO TRTAB-NAME.
    MOVE TRDIR-CDAT TO TRTAB-CDAT.
    MOVE TRDIR-UDAT TO TRTAB-UDAT.

    APPEND TRTAB.

    CLEAR: TEXTTAB.

  ENDSELECT.

ENDFORM. " load_trdir_program
*&---------------------------------------------------------------------*
*& Form load_trdir_fgroup
*&---------------------------------------------------------------------*
FORM LOAD_TRDIR_FGROUP.
  SELECT * FROM TRDIR
        WHERE NAME BETWEEN 'SAPLYYYY'
          AND 'SAPLZZZZ'.

    CHECK TRDIR-UNAM = USER OR TRDIR-CNAM = USER.

    CLEAR: TEXTTAB.
    CLEAR: TRTAB.
    REFRESH: TEXTTAB.

    READ TEXTPOOL TRDIR-NAME INTO TEXTTAB LANGUAGE 'E'.
    IF SY-SUBRC = 0.
      READ TABLE TEXTTAB WITH KEY 'R'.
      MOVE TEXTTAB-ENTRY TO TRTAB-ENTRY.
    ENDIF.

    MOVE TRDIR-NAME TO TRTAB-NAME.
    MOVE TRDIR-CDAT TO TRTAB-CDAT.
    MOVE TRDIR-UDAT TO TRTAB-UDAT.
    APPEND TRTAB.

    CLEAR: TEXTTAB.

  ENDSELECT.

  LOOP AT TRTAB.
    MOVE-CORRESPONDING TRTAB TO TRFTAB.

    APPEND TRFTAB.

    MOVE TRTAB-NAME+3(5) TO W_PROGRAM_LOW.
    MOVE '%' TO W_PROGRAM_LOW+5(1).
    MOVE TRTAB-NAME+3(5) TO W_PROGRAM_HIGH.
    MOVE 'MMMMMMMM' TO W_PROGRAM_HIGH.  

    SELECT * FROM TRDIR WHERE NAME LIKE W_PROGRAM_LOW.
*where name between w_program_low and w_program_high.
      CHECK TRDIR-NAME+5(1) <> '$'.
      CHECK TRDIR-NAME(5) = TRTAB-NAME+3(5).

      READ TEXTPOOL TRDIR-NAME INTO TEXTTAB LANGUAGE 'E'.
      READ TABLE TEXTTAB WITH KEY 'R'.
  
      MOVE TEXTTAB-ENTRY TO TRFTAB-ENTRY.
      MOVE TRDIR-NAME TO TRFTAB-NAME.
      MOVE TRDIR-CDAT TO TRFTAB-CDAT.
      MOVE TRDIR-UDAT TO TRFTAB-UDAT.

      APPEND TRFTAB.

    ENDSELECT.
  ENDLOOP.
ENDFORM. " load_trdir_fgroup.
*---------------------------------------------------------------------*
* FORM PROCESS_PROGRAM *
*---------------------------------------------------------------------*
* ........ *
*---------------------------------------------------------------------*
FORM PROCESS_PROGRAM.

LOOP AT TRTAB.
  READ REPORT TRTAB-NAME INTO ABAPTAB.
  IF DOWNLOAD = 'X'.
    PERFORM DOWNLOAD_PROGRAMS USING TRTAB-NAME. ELSE.
    PERFORM LIST_PROGRAMS USING TRTAB-NAME.
  ENDIF.
  IF pa_TEXTP = 'X'.
    READ TEXTPOOL TRTAB-NAME INTO TEXTTAB LANGUAGE 'E'.
    IF SY-SUBRC = 0 AND DOWNLOAD = 'X'.
      PERFORM DOWNLOAD_TEXTPOOL USING TRTAB-NAME.
    ENDIF.
    LOOP AT TEXTTAB.
      WRITE:/ TEXTTAB-ID, TEXTTAB-KEY, TEXTTAB-ENTRY.
    ENDLOOP.
  ENDIF.
ENDLOOP.

ENDFORM.
*---------------------------------------------------------------------*
* FORM PROCESS_fgroup *
*---------------------------------------------------------------------*
* ........ *
*---------------------------------------------------------------------*
FORM PROCESS_FGROUP.
  LOOP AT TRFTAB.
  READ REPORT TRFTAB-NAME INTO ABAPTAB.
    IF DOWNLOAD = 'X'.
      PERFORM DOWNLOAD_PROGRAMS USING TRFTAB-NAME.  
    ELSE.
      PERFORM LIST_PROGRAMS USING TRFTAB-NAME .
    ENDIF.
    IF pa_TEXTP = 'X'.
      READ TEXTPOOL TRFTAB-NAME INTO TEXTTAB LANGUAGE 'E'.
      IF SY-SUBRC = 0 AND DOWNLOAD = 'X'.
        PERFORM DOWNLOAD_TEXTPOOL USING TRFTAB-NAME.
        LOOP AT TEXTTAB.
          WRITE:/ TEXTTAB-ID, TEXTTAB-KEY, TEXTTAB-ENTRY.
        ENDLOOP.
      ENDIF.
    ENDIF.
  ENDLOOP.
ENDFORM. *&------------------------------------------------------------------*
*& Form DOWNLOAD_PROGRAMS
*&------------------------------------------------------------------*
FORM DOWNLOAD_PROGRAMS USING NAME.
 
W_TEXT = 'Downloading'.
W_TEXT+15(8) = NAME.

CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
     EXPORTING TEXT = W_TEXT
     EXCEPTIONS OTHERS = 1.

clear w_filename.
MOVE DOWNDIR TO W_FILENAME(80).
* MOVE NAME TO W_FILENAME+20(8).
* MOVE '.txt' TO W_FILENAME+28(4).
* CONDENSE W_FILENAME NO-GAPS.
concatenate w_filename name '.txt' into w_filename.
condense w_filename no-gaps.
CALL FUNCTION 'WS_DOWNLOAD'
     EXPORTING FILENAME = W_FILENAME 
     FILETYPE = 'ASC' TABLES DATA_TAB = ABAPTAB
     EXCEPTIONS FILE_OPEN_ERROR = 1
                FILE_WRITE_ERROR = 2
                INVALID_FILESIZE = 3
                INVALID_TABLE_WIDTH = 4
                INVALID_TYPE = 5
                NO_BATCH = 6
                UNKNOWN_ERROR = 7
                OTHERS = 8.
ENDFORM.

" DOWNLOAD_PROGRAMS
*&------------------------------------------------------------------*
*& Form LIST_PROGRAMS
*&------------------------------------------------------------------*
FORM LIST_PROGRAMS USING NAME.

LOOP AT ABAPTAB.
  WRITE:/ NAME, ABAPTAB-LINE.
ENDLOOP.

ENDFORM. " LIST_PROGRAMS
*&---------------------------------------------------------------------*
*& Form DOWNLOAD_TEXTPOOL
*&---------------------------------------------------------------------*
FORM DOWNLOAD_TEXTPOOL USING NAME.

W_TEXT = 'Textpool...'. W_TEXT+15(8) = NAME.

CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
EXPORTING TEXT = W_TEXT
EXCEPTIONS OTHERS = 1.

MOVE DOWNDIR TO W_FILENAME(80).
MOVE TRTAB-NAME TO W_FILENAME+20(8).
MOVE '.tpl' TO W_FILENAME+28(4).
CONDENSE W_FILENAME NO-GAPS.

CALL FUNCTION 'WS_DOWNLOAD'
     EXPORTING FILENAME = W_FILENAME
     FILETYPE = 'ASC'
     TABLES DATA_TAB = TEXTTAB
     EXCEPTIONS FILE_OPEN_ERROR = 1
                FILE_WRITE_ERROR = 2
                INVALID_FILESIZE = 3
                INVALID_TABLE_WIDTH = 4
                INVALID_TYPE = 5
                NO_BATCH = 6
                UNKNOWN_ERROR = 7
                OTHERS = 8.
ENDFORM. " DOWNLOAD_TEXTPOOL

TOP-OF-PAGE.
IF HEADING = 'X'.
* Place your heading here:
* call function 'Z_WRITE_HEADER_FOOTER'
* exporting * type = 'H'
* exceptions * others = 1.
*
* skip 1.
ENDIF.

 

번호 제목 글쓴이 날짜 조회 수
1244 [PDF]Web Dynpro for Beginners.. [7] file 울프 2007.03.19 3626
1243 bdc 프로그램 생성 따라하기 [30] file sapjoy 2007.03.19 9670
1242 BSP Tutorial(영문) [7] file SkyDream 2007.03.19 3484
1241 bapi 사용예제 [10] file sapjoy 2007.03.20 6104
1240 IDOC_INBOUND [10] file 댕댕 2007.03.20 4051
1239 IDOC_OUTBOUND [10] file 댕댕 2007.03.20 3945
1238 CATT 자료 [3] file 댕댕 2007.03.20 3679
1237 SAP Interface overview [5] file 댕댕 2007.03.20 3356
1236 자주 쓰는 펑션 모음 [27] file 댕댕 2007.03.20 10397
1235 스마트 폼 [3] file 댕댕 2007.03.20 4124
1234 [PDF]BC ABAP Workbench Tutorial~ [4] file 하얀콩 2007.03.20 4417
1233 [PDF]BC-ABAP Programming [5] file 하얀콩 2007.03.20 4598
1232 ABAP Key word 문서입니다. [4] file 화니 2007.03.21 4776
1231 ALV개념 정리 [20] file 팡다루 2007.03.22 5614
1230 Background Processing, LUW [10] file 하얀콩 2007.03.23 3535
1229 간단한 SALV 만들기 [13] file 펠릭스 2007.03.23 6132
1228 idoc 이란? [16] file sapjoy 2007.03.26 9761
1227 RFC 호출, Call rfc [11] file sapjoy 2007.03.26 4687
1226 RFC Programming in ABAP [2] file 김관현 2007.03.26 5378
1225 ALV Gird Control 문서 [4] file 김관현 2007.03.26 3573