zoukankan      html  css  js  c++  java
  • [转]整理的函数

    很多经常用到的函数,希望对大家有帮助.

    Funtion:DDIF_FIELDINFO_GET  
      功能:获得字段的相关信息
      参数:
        Import:
          TABNAME:数据库表的名字
          FIELDNAME:无需指定,由LFIELDNAME代替了
          LANGU: 语言设定,默认sy-langu
          LFIELDNAME:指定关联字段
          ALL_TYPES:是否指定所有类型
          GROUP_NAMES:是否包含include的字段
          UCLEN:没用过,应该是和unicode相关的
        Export:
          X030L_WA:返回表头的信息
          DDOBJTYPE:表类型
            'TRANSP'   = transparent table
            'POOL'     = logical pooled table
            'CLUSTER'  = logical cluster table
            'VIEW'     = database or projection view
            'INTTAB'   = structure, help view, maintenance view or structure view
            'TPOOL'    = physical pooled table
            'TCLUSTER' = physical cluster table
            'DTEL'     = data element
            'TTYP'     = table type
          DFIES_WA:没用过
          LINES_DESCR:没用过
        Tables:
          DFIES_TAB:字段列表
          FIXED_VALUES:域的固定值

       说明:该函数可用来获得某个表或者结构或者视图等所有字段的相关信息,所以如果想用alv来维护某个表的时候,对设定field catalog有帮助。

    Funtion:DDIF_NAMETAB_GET    
      功能:获得字段的相关信息(不包含text)
      参数:
        Import:
          TABNAME:数据库表的名字
          LFIELDNAME:指定关联字段
          ALL_TYPES:是否指定所有类型
          GROUP_NAMES:是否包含include的字段
          UCLEN:没用过,应该是和unicode相关的
        Export:
          X030L_WA:返回表头的信息
          DTELINFO_WA:data element的信息
          TTYPINFO_WA:表类型的信息
          DDOBJTYPE:表类型
            'TRANSP'   = transparent table
            'POOL'     = logical pooled table
            'CLUSTER'  = logical cluster table
            'VIEW'     = database or projection view
            'INTTAB'   = structure, help view, maintenance view or structure view
            'TPOOL'    = physical pooled table
            'TCLUSTER' = physical cluster table
            'DTEL'     = data element
            'TTYP'     = table type
          DFIES_WA:没用过
          LINES_DESCR:没用过
        Tables:
          DFIES_TAB:字段列表
          FIXED_VALUES:域的固定值

    Funtion:DDIF_TABL_GET    
      功能:获得表的相关信息
      参数:
        Import:
          NAME:数据库表的名字
          STATE:状态
             STATE = 'A' (read the active version)
             STATE = 'M' (read the latest version)
          LANGU: 语言设定,默认sy-langu
        Export:
          GOTSTATE:状态信息
          DD02V_WA:表头
          DD09L_WA:表表的技术信息
        Tables:
          DD03P_TAB:表的字段列表
          DD05M_TAB:表的外键字段
          DD08V_TAB:表的外键
          DD12V_TAB:表索引
          DD17V_TAB:表的索引字段
          DD35V_TAB:检索help相关
          DD36M_TAB:检索help相关

    Funtion:POPUP_TO_DECIDE_LIST  
      功能:弹出供选择窗口,最多25个选项,选择可以是单选按钮也可以是复选按钮,可以设定最多选择的个数。
      参数:
        Import:
          CURSORLINE  :默认光标所在行
          MARK_FLAG:选择的标志,一般设为‘X’
          MARK_MAX: 最大选择的选项个数
          START_COL:起始行
          START_ROW  :起始列,用来定位弹出窗口的位置
          TEXTLINE1:文本行
          TEXTLINE2:文本行
          TEXTLINE3 :文本行
          TITEL:弹出窗口的标题
          DISPLAY_ONLY:仅显示
        Export:
          ANSWER:A:取消  空:做了选择
        Tables:
          T_SPOPLI:选择结果

    例子:
    REPORT  Z_BOBO                                  .
    * 定义函数需要的变量
    DATA: BEGIN OF SPOPLIST OCCURS 15.
              INCLUDE STRUCTURE SPOPLI.
      DATA: END   OF SPOPLIST.
      DATA: ANTWORT TYPE C.
    * 添加选择参数
      SPOPLIST-VAROPTION = 'Creditor'.
      APPEND SPOPLIST.
      SPOPLIST-VAROPTION = 'Material'.
      APPEND SPOPLIST.
      SPOPLIST-VAROPTION = 'Account '.
      SPOPLIST-SELFLAG   = 'X'.

      CALL FUNCTION 'POPUP_TO_DECIDE_LIST'
         EXPORTING  TITEL            = 'Possible entra: Order'
                   TEXTLINE1        = 'By which criteria'
                   TEXTLINE2        = 'should orders'
                   TEXTLINE3        = 'be selected?'
                   MARK_MAX         = 2
                   MARK_FLAG        = 'X'
        IMPORTING  ANSWER           = ANTWORT
        TABLES     T_SPOPLI         = SPOPLIST
        EXCEPTIONS TOO_MUCH_ANSWERS = 1
                   TOO_MUCH_MARKS   = 2.

      IF SY-SUBRC = 2.
        WRITE: 'Too many answers chosen.'.
      ENDIF.
    * 取消
      IF ANTWORT = 'A'.
        WRITE: 'Popup canceled.'.
      ELSE.
        WRITE: 'Options chosen:'.
        LOOP AT SPOPLIST WHERE SELFLAG = 'X'.
          WRITE: / SPOPLIST-VAROPTION.
        ENDLOOP.
      ENDIF.

    SYSTEM-CALL:DY_GET_FOCUS

      说明:获得屏幕焦点

      参数:

        ID 'SSCREENNAM' FIELD CURRSUBSCREEN
              ID 'SSCREENNBR' FIELD CURRSUBSCREENNO
              ID 'MSCREENNAM' FIELD CURRSCREEN
              ID 'MSCREENNBR' FIELD CURRSCREENNO
              ID 'FIELDNAME' FIELD CURSOR_FIELD
              ID 'FIELDOFFS' FIELD DUMMYOFFS
              ID 'LINE' FIELD CURSOR_LINE.

    SYSTEM-CALL:DY_GET_SET_FIELD_VALUE

      说明:获得或者设置屏幕字段的值

    参数:

    ID 'GET_SET'    FIELD 'S'    "S:Set mode  G:Get mode
          ID 'SSCREENNAM' FIELD SHSUBSCREEN
          ID 'SSCREENNBR' FIELD SHSUBSCREENNO
          ID 'MSCREENNAM' FIELD SHSCREEN
          ID 'MSCREENNBR' FIELD SHSCREENNO
          ID 'FIELDNAME' FIELD DYNP_EXPORT
          ID 'LINE' FIELD DYNP_EXSTEPL
          ID 'VALUE' FIELD DYNP_EXPVAL.

    例子:我做了一个检索help的exit,例如屏幕上有两个字段,我按了一个字段的检索help,那么根据这个字段就会取得相应的另外一个字段的值,然后把这个之设置到第二个字段。

    FUNCTION ZTEST_F4.
    *"----------------------------------------------------------------------
    *"*"Local interface:
    *"  TABLES
    *"      SHLP_TAB TYPE  SHLP_DESCT
    *"      RECORD_TAB STRUCTURE  SEAHLPRES
    *"  CHANGING
    *"     REFERENCE(SHLP) TYPE  SHLP_DESCR
    *"     REFERENCE(CALLCONTROL) LIKE  DDSHF4CTRL STRUCTURE  DDSHF4CTRL
    *"----------------------------------------------------------------------
    * Local data definition
      DATA: L_ZZOINO(3) TYPE C.
      DATA: L_ZZPOSID(10) TYPE C.
      DATA: DYNP_EXPORT(132), DYNP_EXPVAL(132).
      DATA: DYNP_EXSTEPL TYPE I, OK, DUMMYCHAR.
      DATA: DUMMYOFFS TYPE I.
      DATA: SHSUBSCREEN LIKE HELP_INFO-DYNPPROG,
            SHSUBSCREENNO LIKE HELP_INFO-DYNPRO,
            SHSCREEN LIKE HELP_INFO-DYNPPROG,
            SHSCREENNO LIKE HELP_INFO-DYNPRO.
      DATA: CURRSUBSCREEN LIKE HELP_INFO-DYNPPROG,
            CURRSUBSCREENNO LIKE HELP_INFO-DYNPRO,
            CURRSCREEN LIKE HELP_INFO-DYNPPROG,
            CURRSCREENNO LIKE HELP_INFO-DYNPRO.
      DATA: CURSOR_FIELD LIKE DYNPREAD-FIELDNAME, CURSOR_LINE TYPE I.
      DATA: SETCURSOR_AVAILABLE TYPE I.
    * Get record value from record table
      READ TABLE RECORD_TAB INDEX 1.
      L_ZZPOSID = RECORD_TAB+0(10).
      IF SHLP_TAB-INTDESCR-HOTKEY IS INITIAL.
        L_ZZOINO = RECORD_TAB+10(3).
      ENDIF.
    * Check command, if return, set screen
      IF CALLCONTROL-STEP = 'RETTOP'.
    *   Initialize screen, get screen focus
        CALL 'DY_GET_FOCUS'
              ID 'SSCREENNAM' FIELD CURRSUBSCREEN
              ID 'SSCREENNBR' FIELD CURRSUBSCREENNO
              ID 'MSCREENNAM' FIELD CURRSCREEN
              ID 'MSCREENNBR' FIELD CURRSCREENNO
              ID 'FIELDNAME' FIELD CURSOR_FIELD
              ID 'FIELDOFFS' FIELD DUMMYOFFS
              ID 'LINE' FIELD CURSOR_LINE.
    *   Set screen parameter
        GET PARAMETER ID 'RID' FIELD SHSUBSCREEN .
        SHSCREEN = SHSUBSCREEN.
        GET PARAMETER ID 'DYN' FIELD SHSUBSCREENNO.
        SHSCREENNO = SHSUBSCREENNO.
        DYNP_EXPORT   ='V_WA_DYNPRO_9000-ZZOINO'.
        DYNP_EXPVAL   = L_ZZOINO.
    *   System call for set screen
        CALL 'DY_GET_SET_FIELD_VALUE'
          ID 'GET_SET'    FIELD 'S'    "Set mode
          ID 'SSCREENNAM' FIELD SHSUBSCREEN
          ID 'SSCREENNBR' FIELD SHSUBSCREENNO
          ID 'MSCREENNAM' FIELD SHSCREEN
          ID 'MSCREENNBR' FIELD SHSCREENNO
          ID 'FIELDNAME' FIELD DYNP_EXPORT
          ID 'LINE' FIELD DYNP_EXSTEPL
          ID 'VALUE' FIELD DYNP_EXPVAL.
    *   System call for set screen
        DYNP_EXPORT   ='V_WA_DYNPRO_9000-ZZPOSID'.
        DYNP_EXPVAL   = L_ZZPOSID.
        CALL 'DY_GET_SET_FIELD_VALUE'
          ID 'GET_SET'    FIELD 'S'    "Set mode
          ID 'SSCREENNAM' FIELD SHSUBSCREEN
          ID 'SSCREENNBR' FIELD SHSUBSCREENNO
          ID 'MSCREENNAM' FIELD SHSCREEN
          ID 'MSCREENNBR' FIELD SHSCREENNO
          ID 'FIELDNAME' FIELD DYNP_EXPORT
          ID 'LINE' FIELD DYNP_EXSTEPL
          ID 'VALUE' FIELD DYNP_EXPVAL.
      ENDIF.
    ENDFUNCTION.

    Function:F4IF_INT_TABLE_VALUE_REQUEST
      功能:显示检索help
      参数:
         Import:
            DDIC_STRUCTURE:返回table的结构:
              ‘s’:VALUE_TAB的结构
              ‘c’:VALUE_TAB只有一个字段
            RETFIELD:返回的字段名称------------必输
            DYNPPROG:当前程序
            DYNPNR:  屏幕号
            DYNPROFIELD:屏幕上需要检索help的字段名称
            WINDOW_TITLE:检索help的标题
            VALUE_ORG:检索help屏幕显示属性:
            ‘c’:cell by cell
            ‘s’:structured
            CALLBACK_PROGRAM:在f4之前调用的程序
            CALLBACK_FORM:在f4之前调用的程序里面的form名称,形式如下
               FORM <NAME> TABLES RECORD_TAB STRUCTURE SEAHLPRES
                        CHANGING SHLP TYPE SHLP_DESCR
                                  CALLCONTROL LIKE DDSHF4CTRL.
         Export:
            USER_RESET:如果没有选择(按红x),返回‘x’
         Tables:
            VALUE_TAB:传进去的表-----------必输
            FIELD_TAB:Fields of the hit list(暂时没用)
            RETURN_TAB:返回值表,即如果选择了而没有写到屏幕上的值存在这个表中。
            DYNPFLD_MAPPING:把屏幕上需要help的字段可以放在这个表中。
               推测:如果屏幕上有多个字段关联,那么只作一个help的话,这个应该可以满足。

    例子:
    FORM A3000_SET_F4_FIELD_WERKS USING P_FIELD.
    TYPES:
      BEGIN OF T_S_WERKS,
        WERKS TYPE T001W-WERKS,   "プラント
        NAME1 TYPE T001W-NAME1,   "名称
        NAME2 TYPE T001W-NAME2,   "名称2
        STRAS TYPE T001W-STRAS,   "地名/番地-号
        ORT01 TYPE T001W-ORT01,   "市区町村名
      END OF T_S_WERKS.
    TYPES  T_I_WERKS TYPE STANDARD TABLE OF T_S_WERKS.
    *这个就是value_tab
    DATA   L_IT_WERKS TYPE T_I_WERKS.
    *取数据
      SELECT WERKS    "プラント
             NAME1    "名称
             NAME2    "名称 2
             STRAS    "地名/番地-号
             ORT01    "市区町村名
        FROM T001W
        INTO CORRESPONDING FIELDS OF TABLE L_IT_WERKS.
    *调用函数
      CALL FUNCTION 'F4IF_INT_TABLE_VALUE_REQUEST'
        EXPORTING
          RETFIELD                   = 'WERKS'    “plant
          DYNPPROG                 = SY-REPID   “程序名
          DYNPNR                      = SY-DYNNR   “屏幕号
          DYNPROFIELD             = P_FIELD    “字段名称
          VALUE_ORG                = 'S'        “显示属性:cell by cell
        TABLES
          VALUE_TAB                = L_IT_WERKS
        EXCEPTIONS
          PARAMETER_ERROR  = 1
          NO_VALUES_FOUND    = 2
          OTHERS                     = 3

    IF SY-SUBRC <> 0.
         MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
                 WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
      ENDIF.
    ENDFORM.                    " A3000_SET_F4_FIELD_WERKS

    Function: READ_TEXT/CREATE_TEXT
      功能:读取长文本/创建长文本
      参数:
      Import:
        CLIENT:集团
        ID:文本ID(TTXID中定义)
        LANGUAGE:语言
        NAME:文本名字()
        OBJECT:文本对象(TTXOB中定义)
      Export:
        HEADER:文本的描述信息
      Tables:
        LINES:文本内容

    例子:读取销售订单头文本
         CALL FUNCTION 'READ_TEXT'
            EXPORTING
              ID                          = ‘Y001’
              LANGUAGE              = SY-LANGU
              NAME                     = ‘385’
              OBJECT                  = ‘VBBK’
            TABLES
              LINES                     = L_IT_LINES
            EXCEPTIONS
              ID                                            = 1
              LANGUAGE                                = 2
              NAME                                       = 3
              NOT_FOUND                              = 4
              OBJECT                                     = 5
              REFERENCE_CHECK                   = 6
              WRONG_ACCESS_TO_ARCHIVE = 7
              OTHERS                                    = 8.

    Function: CONVERSION_EXIT_CUNIT_OUTPUT
      功能:根据语言决定单位的显示
      参数:
        Import:
          INPUT:内部单位显示方式
          LANGUAGE:语言代码
        Export:
          LONG_TEXT:单位的长文本
          OUTPUT:外部单位显示方式
          SHORT_TEXT:单位的短文本

    例子:单位显示转换
          CALL FUNCTION 'CONVERSION_EXIT_CUNIT_OUTPUT'
          EXPORTING
            INPUT                   = ‘ST’
            LANGUAGE            = SY-LANGU
          IMPORTING
            OUTPUT                = L_OUT
          EXCEPTIONS
            UNIT_NOT_FOUND = 1
            OTHERS                = 2.

    Function: SJIS_DBC_TO_SBC
      功能:全角转换为半角
      参数:
        Import:
          ALL:全部转换
          ALPHABET_UPPER:A-Z转换
          ALPHABET_LOWER:a-z转换
          NUMERIC:0-9转换
        Export:
          CONVERTED:转换的字符个数
        Changing:
          TEXT:转换结果

    Function: SJIS_SBC_TO_DBC
      功能:半角转换为全角
      参数:
        Import:
          ALL:全部转换
          ALPHABET_UPPER:A-Z转换
          ALPHABET_LOWER:a-z转换
          NUMERIC:0-9转换
        Export:
          CONVERTED:转换的字符个数
        Changing:
          TEXT:转换结果

    Function: CO_R0_CHECK_DECIMAL_POINT
      功能:根据单位检查数据的小数位
      参数:
        Import:
          I_QUANTITY:数量
          I_UNIT:单位
       例子:下面的例子会返回错误信息,以为单位ST是不能有小数位的。
            CALL FUNCTION 'CO_R0_CHECK_DECIMAL_POINT'
              EXPORTING
                I_QUANTITY       = 3.2
                I_UNIT               =‘ST’
              EXCEPTIONS
                WRONG_DATA     = 1
                OTHERS               = 2.

    Function: POSTAL_CODE_CHECK
      功能:检查邮政编码
      参数:
        Import:
          COUNTRY:国家(T005)----------必输
          ONE_TIME_ACCOUNT:不明确
          POSTAL_CODE:邮政编码
          POSTAL_CODE_PO_BOX:没用过,以下为推测:如果输入则会检查,如果t005表中的XPLPF设置了,那么如果输入PO_BOX,这个选项就必须输入。
           PO_BOX:没用过
           REGION:区域
        Export:
          POSTAL_CODE:邮编
          EV_POSTAL_CODE:邮编的格式
          EV_POSTAL_CODE_PO_BOX:没用过

    Funtion:CONVERSION_EXIT_ALPHA_INPUT
      功能:全数字则在前面补0
      参数:
        Import:
          INPUT:输入的字符串
        Export:
          OUTPUT:输出的字符串

    Funtion:CONVERSION_EXIT_ALPHA_OUTPUT
      功能:和上面相反

    Funtion:GET_JOB_RUNTIME_INFO
      功能:获得job相关信息
      参数:
        Export:
         EVENTID:后台处理的事件id
         EVENTPARM:后台事件的参数(例如,job id,job名字)
         TERNAL_PROGRAM_ACTIVE:没用过
         JOBCOUNT:job id
         JOBNAME:job 名称

    Funtion:TERMINAL_ID_GET
      功能:获得端末id
      参数:
        Import:
          USERNAME:用户名
        Export:
          TERMINAL:terminal id

    Funtion:DATE_CONVERT_TO_FACTORYDATE
    功能:把输入日期转为工厂日历日期
      参数:
        Import:
          CORRECT_OPTION:表示工作日计算方式的标记  
          DATE:必须转化为工厂日历日期的日期 
          FACTORY_CALENDAR_ID:工厂日历 ID    
        Export:
          DATE:必须转化为工厂日历日期的日期   
          FACTORYDATE:指定日历中的工作日数      
          WORKINGDAY_INDICATOR:表示某日期是否为工作日的标志   

    例子:
    DATA: DATE1        LIKE SCAL-DATE,
          DATE2        LIKE SCAL-DATE,
          CORRECTION   LIKE SCAL-INDICATOR,
          CALENDAR     LIKE SCAL-FCALID,
          FACTORYDATE  LIKE SCAL-FACDATE,
          WORKDAY      LIKE SCAL-INDICATOR.
          CALL FUNCTION 'DATE_CONVERT_TO_FACTORYDATE'
               EXPORTING  DATE                 = DATE1
                           CORRECT_OPTION       = CORRECTION
                           FACTORY_CALENDAR_ID  = CALENDAR
               IMPORTING  DATE                 = DATE2
                           FACTORYDATE          = FACTORYDATE
                           WORKINGDAY_INDICATOR = WORKDAY
               EXCEPTIONS CORRECT_OPTION_INVALID     = 1
                            DATE_AFTER_RANGE           = 2
                           DATE_BEFORE_RANGE          = 3
                           DATE_INVALID               = 4
                           FACTORY_CALENDAR_NOT_FOUND = 5.

    Funtion:MESSAGE_TEXT_BUILD
      功能:把消息转为文本
      参数:
        Import:
          MSGID:消息id
          MSGNR:消息号
          MSGV1:参数1
          MSGV2:参数2
          MSGV3:参数3
          MSGV4:参数4
        Export:
          MESSAGE_TEXT_OUTPUT:输出的字符串
      说明:可以用write <message> to <text>代替

    Function: POPUP_TO_CONFIRM
    Group:SPO1
      功能:弹出确认窗口
      参数:
        Import:
          TITLEBAR:弹出窗口的标题,最多40位
          TEXT_QUESTION:问题,最长80位,多出来的截断
          TEXT_BUTTON_1:第一按钮的text,最长8位
          ICON_BUTTON_1:第一按钮显示的icon
          TEXT_BUTTON_2:第二按钮的text,最长8位
          ICON_BUTTON_2:第二按钮显示的icon
          DEFAULT_BUTTON:默认的按钮
          DISPLAY_CANCEL_BUTTON:是否显示取消
          POPUP_TYPE:弹出的类型: 决定显示的icon
             ICON_MESSAGE_QUESTION :问题
              ICON_MESSAGE_INFORMATION:信息
              ICON_MESSAGE_WARNING:警告
              ICON_MESSAGE_ERROR:错误
              ICON_MESSAGE_CRITICAL:冲突
          START_COLUMN:弹出位置:列
          START_ROW:弹出位置:行
          IV_QUICKINFO_BUTTON_1:第一按钮的显示信息(鼠标放上去后看到的)
          IV_QUICKINFO_BUTTON_2:第二按钮的显示信息(鼠标放上去后看到的)
        Export:
          ANSWER:返回点击的按钮
            '1' :第一个按钮
             '2' :第二个按钮
             'A' :取消按钮

    Function: CS_BOM_EXPL_MAT_V2
      功能:BOM展开
      参数:
        Import:
          CAPID:application id
         DATUV:有效开始日
         EMENG:数量
         MTNRV:物料
         MEHRS:多阶层bom展开
         WERKS:工厂
         STLAN:bom用途
        Tables:
          STB:展开明细
      说明:一般定义上面几个参数就可以了,鉴于该函数参数太多,就不一一说明了

     Function: CLOI_PUT_SIGN_IN_FRONT
      功能:将负号提前
      参数:
        Changing:
          VALUE:需要负号提前的变量

    Function: EPS_GET_DIRECTORY_LISTING
      功能:获得某路径下的文件列表
      参数:
        Import:
          DIR_NAME:需要查找的路径
          FILE_MASK:没用过
        Export:
          DIR_NAME:文件路径
          FILE_COUNTER:文件个数
          ERROR_COUNTER:错误的个数
        Tables:
          DIR_LIST:文件列表
      说明:这个函数可以获得服务器某个路径下的所有文件,对open dataset for read file中file名字的获得有帮助。

    Function: BAPI_COMPANYCODE_GET_PERIOD
      功能:获得公司的会计年度以及过账日期
      参数:
        Import:
          COMPANYCODEID:公司代码
          POSTING_DATE:posting date
        Export:
          FISCAL_YEAR:会计年度
          FISCAL_PERIOD:财务期间
          RETURN:返回值
       说明:该函数可用来检查会计期间。

    Function: MARA_SINGLE_READ
      功能:读取物料信息
      参数:
        Import:
          KZRFB:Indicator: Refresh buffer entry
          MAXTZ:Max. no. of entries in buffer(这两个参数应该和性能优化相关)
          MATNR:物料号
          SPERRMODUS:Lock mode (none, shared, excl.)
          STD_SPERRMODUS:Standard lock mode (if different)(锁相关)
          OUTPUT_NO_MESSAGE:是否输出消息
        Export:
          WMARA:返回的物料信息
       说明:该函数可用于性能优化,例如无法避免在loop中有sql的情况可以用该函数取代sql。
             对mara的其它操作参考function group:MG21

    Function: KNA1_SINGLE_READ
      功能:读取customer表信息
      参数:
        Import:
          KZRFB:Indicator: Refresh buffer entry
          KNA1_KUNNR:customer code
        Export:
          WKNA1:返回的信息
       说明:还有很多表的读取参考function group:MG41

    Function: ADDR_GET_COMPLETE_ALL_TYPES
      功能:获得地址的相关信息
      参数:
        Import:
          ADDRNUMBER:address number
          PERSNUMBER:个人信息
          ADDRESS_OBJECT_TYPE:类型 1:组织 2:个人 3:客户
        Export:
          ADDR1_COMPLETE:地址1
          ADDR2_COMPLETE:地址2
          ADDR3_COMPLETE:地址3
          ADDR1_COMPLETE_BAPI:地址1
          ADDR2_COMPLETE_BAPI:地址2
          ADDR3_COMPLETE_BAPI:地址3(以上三个bapi用)

    Function: READ_VBFA
      功能:取得document flow(省得select了)
      参数:
        Import:
          I_VBELV:Preceding sales and distribution document
          I_POSNV:Preceding item of an SD document
          I_VBTYP_V:Document category of preceding SD document
          I_VBTYP_N:Document category of subsequent document
          I_FKTYP:Billing category
          I_BYPASSING_BUFFER:是否用buffer
          I_REFRESH_BUFFER:删除buffer?
        Tables:
          E_VBFA:凭证流的表
       说明:可以通过by passing buffer来优化性能

    Function: SD_VBAK_SINGLE_READ
      功能:读取销售订单表头信息
      参数:
        Import:
          I_VBELN:销售订单
          I_BYPASSING_BUFFER:是否用buffer
          I_REFRESH_BUFFER:删除buffer?
        Export:
          E_VBAK:返回表头信息
       说明:读相关sd表的函数请参考function group:V45I

    Function: LIKP_READ
      功能:Delivery Header Data
      参数:
        Import:
          I_VBELN:Delivery
          LINE_EXIST:if 'x' check only if line exsists
        Export:
          O_ANSWR:send out 'x' for line exsists in table
        Tables:
          E_LIKP:SD Document: Delivery Header Data
       说明:有关读取delivery的信息请参考function group:LMGT

    Function: CREATE_SAP_SHORTCUT
      功能:创建快捷方式
      参数:
        Import:
          SC_COMMAND:指定的tcode
          SC_TITLE:快捷方式名字:例如:se38
          SC_TYPE:快捷方式类型:有三种:’report’,’ transaction’,’ system command’
          NO_DIALOG:是否弹出窗口
       说明:具体没什么用,做着玩玩。

    Function: SAPGUI_PROGRESS_INDICATOR
      功能:显示进度
      参数:
        Import:
          PERCENTAGE:进度的百分数,>0,<100.
          TEXT:文本
    说明:在运行时间很长的程序中可以选择使用,这样保证了程序不会中止。当然也可以在rz10里面设置程序运行时间,不过比较麻烦。

    Funtion:K_GROUP_SELECT     
      功能:利润中心组的检索help
      参数:
        Import:
          BUTTONS:按钮,决定是否可以选择group类型
          CLASS  :cost center class
          CRUSER:创建人
          FIELD_NAME:字段名称:此项为必输项
          SEARCHFLD:还没用过
          SEARCHFLD_INPUT:成本控制范围是否可以输入(参照图1)
          SEARCHFLD_REQUIRED:成本控制范围是否必输,如果设置为不可输入,
                              那么这个参数无效(参考图2)
          SET:利润中心组的开头字母
          START_COLUMN:弹出窗口的位置
          START_ROW  :弹出窗口的位置
          TABLE:表或者结构的名称
        Export:
          SET_NAME:取得帮助字段的值
     例子
    *&---------------------------------------------------------------------
    *& Report  Z_BOBO_20060228                                        *
    *&---------------------------------------------------------------------*
    *& 弹出窗口,利润中心组的帮助,这样就省得f4_value_request了  *                                                                          *
    *&---------------------------------------------------------------------*

    REPORT  Z_BOBO_20060228                         .
    DATA : W_PRCGC1(15)     TYPE C.
    DATA : W_SETNAME(15)    TYPE C.
    SELECT-OPTIONS : S_PRCGC  FOR  W_PRCGC1.     " 利润中心组
    AT SELECTION-SCREEN.
    AT SELECTION-SCREEN ON VALUE-REQUEST FOR S_PRCGC-LOW.
       CALL FUNCTION 'K_GROUP_SELECT'
         EXPORTING
           BUTTONS              = 'X'
           CLASS                  = '0106'
           FIELD_NAME          = 'RPRCTR'
           SEARCHFLD_INPUT  = 'X'
           SEARCHFLD_REQUIRED = 'X'
           SET                        = '@'
           TABLE                     = 'CCSS'
         IMPORTING
           SET_NAME                = W_SETNAME
         EXCEPTIONS
           NO_SET_PICKED      = 1
           OTHERS                = 2.
       IF SY-SUBRC <> 0.
    * MESSAGE ID SY-MSGID TYPE SY-MSGTY NUMBER SY-MSGNO
    *         WITH SY-MSGV1 SY-MSGV2 SY-MSGV3 SY-MSGV4.
       ELSE.
         S_PRCGC-LOW  = W_SETNAME.
       ENDIF.
    START-OF-SELECTION.
       WRITE: 'TEST BOBO'.  
      
    function:SD_VBAP_READ_WITH_VBELN
    功能:根据销售订单读取表vbap中的信息
    参数:
      import:I_VBELN                          订单号(必输项)
                  I_BYPASSING_BUFFER     是否回避buffer
                  I_REFRESH_BUFFER         是否清空buffer
      tables:ET_VBAPVB                        不清楚其意义
                       ET_VBAP                            vbap表

    form:EDIT_LINES
    功能:把READ_TEXT返回的LINES中的行按照TDFORMAT=“*”重新组织
    原因:如果用CREATE_TEXT登录的长文本不存在该问题,如果是在前台业务登录的text,那么存到数据库的时候会在72位的地方换行,在lines这个表中的TDFORMAT设置为空,导致READ_TEXT返回的表中的行数也许不是你需要的行数。
    代码:
    FORM EDIT_LINES TABLES P_IT_LINES STRUCTURE TLINE.
      DATA:
        L_IT_LINES TYPE STANDARD TABLE OF TLINE,
        L_WA_LINES TYPE TLINE,
        L_WA_LINE1 TYPE TLINE,
        L_LINE TYPE I.
      DATA:
        L_INDEX TYPE I,
        L_I     TYPE I.
      READ TABLE P_IT_LINES TRANSPORTING NO FIELDS
        WITH KEY TDFORMAT = SPACE.
      CHECK SY-SUBRC = 0.
      L_LINE = LINES( P_IT_LINES ).
      CHECK L_LINE > 1.

      L_IT_LINES[] = P_IT_LINES[].
      CLEAR: P_IT_LINES[].

      L_INDEX = 2.
      DO.
        CLEAR: L_WA_LINES.
        READ TABLE L_IT_LINES INTO L_WA_LINES INDEX L_INDEX.
        IF SY-SUBRC <> 0.
          L_I = L_INDEX - 1.
          READ TABLE L_IT_LINES INTO L_WA_LINES INDEX L_I.
          IF SY-SUBRC = 0 .
            APPEND L_WA_LINES TO P_IT_LINES.
          ENDIF.
          EXIT.
        ENDIF.
        IF L_WA_LINES-TDFORMAT = '*'.
          L_I = L_INDEX - 1.
          CLEAR L_WA_LINE1.
          READ TABLE L_IT_LINES INTO L_WA_LINE1 INDEX L_I.
          APPEND L_WA_LINE1 TO P_IT_LINES.
          L_INDEX = L_I + 2.
        ELSE.
          L_I = L_INDEX - 1.
          READ TABLE L_IT_LINES INTO L_WA_LINE1 INDEX L_I.
          CONCATENATE L_WA_LINE1-TDLINE L_WA_LINES-TDLINE
                 INTO L_WA_LINE1-TDLINE.
          APPEND L_WA_LINE1 TO P_IT_LINES.
          L_INDEX = L_INDEX + 2.
        ENDIF.
      ENDDO.
    ENDFORM.                    " S4110_EDIT_LINES

    function:VIEW_MAINTENANCE_CALL
    功能:维护表视图等
    The function module calls the extended table maintenance (View maintenance).
    参数:
    import:ACTION       S = Display U = Change T = Transport
                CORR_NUMBER  传送号(上面的action是t)
                SHOW_SELECTION_POPUP   是否弹出选择画面
                VIEW_NAME    视图名
                NO_WARNING_FOR_CLIENTINDEP  跨集团是否现实警告
                VARIANT_FOR_SELECTION   变式名
                CHECK_DDIC_MAINFLAG     察看是否为可维护对象
    其他的参数暂时没有用到,有用到的朋友可以补充

    
    
     
    
    
    
     
    
    今天介绍JOB相关的几个函数:
    
    1.  JOB_OPEN
    
         IMPORT:
    
           DELANFREP:这里设定在JOB执行完毕之后是否删除JOB
    
           JOBGROUP:JOB分配个某个组,一般用不到
    
           JOBNAME:JOB的名字,这个名字方便你在SM37中察看
    
           JOBCLASS:没用过,不知道有什么作用
    
         EXPORT:
    
           JOBCOUNT:返回的JOB的ID
    
         CHANGING:
    
           RET:判断函数的执行情况
    
    2.  JOB_SUBMIT
    
         IMPORT:
    
           AUTHCKNAM:检查权限,传入用户名
    
           JOBCOUNT:一般是传入刚才取到的JOB ID
    
           JOBNAME:JOB的名字
    
           REPORT:执行JOB的程序名字
    
           VARIANT:JOB执行时候的变式
    
    3.  JOB_CLOSE
    
         IMPORT:
    
           JOBCOUNT:一般是传入刚才取到的JOB ID
    
           JOBNAME:JOB的名字
    
     
    
    这三个函数是JOB程序的主要处理流程,其中我只列出了主要用的参数,
    
    至于其他的如果哪位朋友用到可以补充一下。
    
     
    
    需要注意一点就是JOB_CLOSE的时候要分两种情况,一种是周期性JOB的关闭,
    
    另一种是即时JOB的关闭。控制的参数需要多指定一些:
    
    周期性JOB:
    
      PREDJOB_CHECKSTAT:检查JOB执行的状态
    
      PRED_JOBNAME:周期性JOB的名字
    
    即时性JOB:
    
      STRTIMMED:这个参数设置为’X’
    
    
    
    

    方法: FILE_OPEN_DIALOG

    *数据的定义

    DATA: TAB         TYPE FILETABLE,         "存放文件名的内表

          WA          TYPE LINE OF FILETABLE, "用来读取文件名的结构

          FILE_FILTER TYPE STRING,            "file filter

          RC          TYPE I.                 "函数返回值

    *定义file filter,注意定义的格式,显示的时候最后一个为默认的显示

    *与你定义的DEFAULT_EXTENSION无关

    FILE_FILTER = 'All Files (*.*)|*.*|Excel Files (*.xls)|*.xls|Word files(*.doc)|*.doc'.

    *这就是打开文件的函数,或者说方法也行

    CALL METHOD CL_GUI_FRONTEND_SERVICES=>FILE_OPEN_DIALOG

      EXPORTING

    *   对话框的标题  

        WINDOW_TITLE            = 'WINDOW_TITLE'

    *   默认的文件后缀名    

        DEFAULT_EXTENSION       = '*.DOC'

    *   默认打开的文件名    

        DEFAULT_FILENAME        = 'C:\TEST'

    *   文件打开的filter    

        FILE_FILTER             = FILE_FILTER

    *   初始化的目录    

        INITIAL_DIRECTORY       = 'C:\'

    *   是否可以同时打开多个文件

        MULTISELECTION          = 'X'

      CHANGING

    *   你所打开的文件名字列表  

        FILE_TABLE              = TAB

    *   返回值,如果成功打开了,为1    

        RC                      = RC

      EXCEPTIONS

        FILE_OPEN_DIALOG_FAILED = 1

        CNTL_ERROR              = 2

        ERROR_NO_GUI            = 3

        NOT_SUPPORTED_BY_GUI    = 4

        others                  = 5

            .

    IF SY-SUBRC = 0.

      READ TABLE TAB INDEX 1 INTO WA.

      WRITE: WA. ENDIF.

     

  • 相关阅读:
    反射机制小结
    IO流小节
    C# 利用file打印日志
    JS判断表单内容是否更改过
    input file 样式以及获取选择文件方法集合
    JS判断终端浏览器类型
    Node.js服务的重启与监控
    ASP.NET MVC 与Form表单交互
    JS 更改表单的提交时间和Input file的样式
    My SQL和LINQ 实现ROW_NUMBER() OVER以及Fatal error encountered during command execution
  • 原文地址:https://www.cnblogs.com/wequst/p/1513852.html
Copyright © 2011-2022 走看看