Chinaunix首页 | 论坛 | 博客
  • 博客访问: 7133946
  • 博文数量: 655
  • 博客积分: 10264
  • 博客等级: 上将
  • 技术积分: 8278
  • 用 户 组: 普通用户
  • 注册时间: 2007-06-04 17:47
个人简介

ABAP顾问

文章分类

全部博文(655)

文章存档

2017年(2)

2014年(8)

2013年(3)

2012年(2)

2011年(18)

2010年(102)

2009年(137)

2008年(274)

2007年(134)

分类:

2010-07-23 14:44:44

REPORT  z_barry_check_cr.
 
TABLES: sscrfields.
DATA: bdcdata LIKE bdcdata    OCCURS 0 WITH HEADER LINE.
DATA: BEGIN OF messtab OCCURS 0.
        INCLUDE STRUCTURE bdcmsgcoll.
DATA: END OF messtab.
DATA: BEGIN OF itab OCCURS 0 ,
        line(20) ,
      END OF itab.
DATA: BEGIN OF up_file OCCURS 0 ,
        pgmid           LIKE e071-pgmid,
        object          LIKE e071-object,
        obj_name        LIKE e071-obj_name,
      END OF up_file.
 
PARAMETERS mode LIKE ctu_params-dismode DEFAULT 'E'  .
SELECTION-SCREEN SKIP.
SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(20)   T1.
SELECTION-SCREEN POSITION 24.
PARAMETERS  status1 AS CHECKBOX.
SELECTION-SCREEN COMMENT 26(12)   T2.
PARAMETERS  status2 DEFAULT 'X' AS CHECKBOX.
SELECTION-SCREEN COMMENT 41(12)  T3.
SELECTION-SCREEN END OF LINE.
SELECTION-SCREEN FUNCTION KEY 1.
 
INITIALIZATION.
  sscrfields-functxt_01 = '限制Request值'.
  t1 = 'Request Status'.
  t2 = 'Modifiable'.
  t3 = 'Released'.
 
AT SELECTION-SCREEN.
  CHECK sy-ucomm = 'FC01'.
  EDITOR-CALL FOR itab TITLE '输入Request值'.
  DELETE itab WHERE LINE = ''.
 
START-OF-SELECTION.
  PERFORM upfile.
  PERFORM bdc.
 
*&---------------------------------------------------------------------*
*&      Form  upfile
*&---------------------------------------------------------------------*
FORM upfile.
  CALL FUNCTION 'GUI_UPLOAD'
    EXPORTING
      filename            = 'C:\checkcr.txt'
      has_field_separator = 'X'
    TABLES
      data_tab            = up_file
    EXCEPTIONS
      OTHERS              = 17.
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
            WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.
 
  DELETE up_file WHERE  pgmid = '' AND object ='' AND obj_name = '' .
 
  LOOP AT up_file WHERE pgmid = '' OR object ='' OR obj_name = '' .
    MESSAGE e000(oo) WITH '文件有错,存在空字段'.
  ENDLOOP.
ENDFORM.                    "upfile
*&---------------------------------------------------------------------*
*&      Form  bdc
*&---------------------------------------------------------------------*
FORM bdc.
  CLEAR: bdcdata,bdcdata[].
  PERFORM bdc_dynpro  USING 'SAPLWBABAP'         '0100'.
  PERFORM bdc_field   USING 'BDC_OKCODE'         '=STRT'.
  PERFORM bdc_field   USING 'RS38M-PROGRAMM'     'RSWBO040'.
  PERFORM bdc_field   USING 'RS38M-FUNC_EDIT'    'X'.
 
  IF itab[] IS NOT INITIAL.
    PERFORM bdc_dynpro  USING 'RSWBO040'         '1000'.
    PERFORM bdc_field   USING 'BDC_OKCODE'       '=%104'.
    LOOP AT itab.
      PERFORM bdc_dynpro  USING 'SAPLALDB'       '3000'.
      PERFORM bdc_field   USING 'BDC_OKCODE'     '=P+'.
      PERFORM bdc_field   USING 'BDC_CURSOR'     'RSCSEL-SLOW_I(02)'.
      PERFORM bdc_field   USING 'RSCSEL-SLOW_I(02)' itab-line .
    ENDLOOP.
    PERFORM bdc_dynpro  USING 'SAPLALDB'       '3000'.
    PERFORM bdc_field   USING 'BDC_OKCODE'     '=ACPT'.
  ENDIF.
 
  LOOP AT up_file.
    PERFORM bdc_dynpro  USING 'RSWBO040'     '1000'.
    PERFORM bdc_field   USING 'BDC_OKCODE'   '=ONLI'.
    PERFORM bdc_field   USING 'CHECKA'       'X'.
    PERFORM bdc_field   USING 'OBJECTA'      up_file-object .
    PERFORM bdc_field   USING 'OBJNAMEA'     up_file-obj_name .
    PERFORM bdc_field   USING 'STATUS1'      status1.
    PERFORM bdc_field   USING 'STATUS2'      status2 .
  ENDLOOP.
 
  PERFORM bdc_dynpro  USING 'RSWBO040'     '1000'.
  PERFORM bdc_field   USING 'BDC_OKCODE'   '/EE'.
  PERFORM bdc_dynpro  USING 'SAPLWBABAP'   '0100'.
  PERFORM bdc_field   USING 'BDC_OKCODE'   '=BACK'.
  CALL TRANSACTION 'SE38' USING bdcdata MODE mode  .
ENDFORM.                    "bdc
 
*----------------------------------------------------------------------*
*        Start new screen                                              *
*----------------------------------------------------------------------*
FORM bdc_dynpro USING program dynpro.
  CLEAR bdcdata.
  bdcdata-program  = program.
  bdcdata-dynpro   = dynpro.
  bdcdata-dynbegin = 'X'.
  APPEND bdcdata.
ENDFORM.                    "BDC_DYNPRO
*----------------------------------------------------------------------*
*        Insert field                                                  *
*----------------------------------------------------------------------*
FORM bdc_field USING fnam fval.
  CLEAR bdcdata.
  bdcdata-fnam = fnam.
  bdcdata-fval = fval.
  CONDENSE bdcdata-fval.
  APPEND bdcdata.
ENDFORM.                    "BDC_FIELD
阅读(2909) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~