REPORT YTEST_BARRY. TYPES:BEGIN OF TY_OUT, MATNR TYPE MAKT-MATNR, MAKTX TYPE MAKT-MAKTX, MENGE TYPE VBAP-KWMENG , END OF TY_OUT. DATA IT_TAB TYPE TABLE OF TY_OUT . DATA WA_TAB TYPE TY_OUT . START-OF-SELECTION . PERFORM CLIPTOITAB TABLES IT_TAB.
*----------------------------------------------------------------------* * 剪貼板數據到內表,根據製表符分割 * 若是有數據類型錯誤,好比內表是數值型可是剪貼板裏面是字母, * 則彈出W消息,並忽略這條數據 *----------------------------------------------------------------------*
FORM CLIPTOITAB TABLES ITAB. DATA: HTAB TYPE C VALUE CL_ABAP_CHAR_UTILITIES=>HORIZONTAL_TAB . DATA: LT_CLIP TYPE TABLE OF CHAR2048 WITH HEADER LINE , LT_FLD TYPE TABLE OF CHAR2048 WITH HEADER LINE. DATA: CXROOT TYPE REF TO CX_ROOT, EXCMSG TYPE STRING. FIELD-SYMBOLS:<FS_FLD> , <FS_TAB> . ASSIGN ITAB TO <FS_TAB> . CALL METHOD CL_GUI_FRONTEND_SERVICES=>CLIPBOARD_IMPORT IMPORTING
DATA = LT_CLIP[] EXCEPTIONS CNTL_ERROR = 1 ERROR_NO_GUI = 2 NOT_SUPPORTED_BY_GUI = 3 OTHERS = 4. IF SY-SUBRC <> 0. MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4 . ELSE. CALL METHOD CL_GUI_CFW=>FLUSH . LOOP AT LT_CLIP. CLEAR LT_FLD[]. SPLIT LT_CLIP AT HTAB INTO TABLE LT_FLD. LOOP AT LT_FLD. ASSIGN COMPONENT SY-TABIX OF STRUCTURE <FS_TAB> TO <FS_FLD>. CHECK SY-SUBRC = 0.
TRY . LT_FLD = TRANSLATE( VAL = LT_FLD FROM = |\r| TO = '' ). LT_FLD = TRANSLATE( VAL = LT_FLD FROM = |\n| TO = '' ). LT_FLD = TRANSLATE( VAL = LT_FLD FROM = |"| TO = '' ).
LT_FLD = TRANSLATE( VAL = LT_FLD FROM = |D| TO = '' ). "測試
****以上處理字符中多餘數據 空格 換行等 <FS_FLD> = LT_FLD.
****如下獲取異常數據 CATCH CX_ROOT INTO CXROOT. EXCMSG = CXROOT->GET_TEXT( ). ENDTRY. ENDLOOP. APPEND ITAB . CLEAR ITAB. ENDLOOP. IF EXCMSG IS NOT INITIAL. MESSAGE W000(OO) WITH '數據轉換有錯誤發生,已經忽略'. ENDIF. ENDIF. ENDFORM.