【转】
REPORT zbdc_test_by_shir.

* 定义个BDC格式的内表
**************************************************
DATA : BEGIN OF i_bdcdata OCCURS 0,
*BDC的程序名字,比如事物码MM01的程序名字为SAPLMGMM(sap标准程序)
         program LIKE bdcdata-program,
*BDC Dynpro 号码
         dynpro LIKE bdcdata-dynpro,
*BDC BDC Dynpro 開始
         dynbegin LIKE bdcdata-dynbegin,
*BDC 项目名字
         fnam LIKE bdcdata-fnam,
*BDC 项目名字的附加值
         fval LIKE bdcdata-fval,
       END OF i_bdcdata.
*BDC
DATA: t_bdcmsg LIKE bdcmsgcoll  OCCURS 0 WITH HEADER LINE.
*****此方法可以用excel,txt等文件导入
DATA: BEGIN OF itab OCCURS 0,
        maktx  LIKE makt-maktx,
        meins  LIKE mara-meins,
        matkl  LIKE mara-matkl,
      END   OF itab.

DATA: tab LIKE itab OCCURS 0 WITH HEADER LINE.
DATA: BEGIN OF t_log OCCURS 0,
         information(289) TYPE c,   "返回信息
      END OF t_log.
DATA:BEGIN OF iexcel OCCURS 0.
        INCLUDE STRUCTURE alsmex_tabline.
DATA:END OF iexcel.
FIELD-SYMBOLS: <fs>.
SELECTION-SCREEN BEGIN OF BLOCK text WITH FRAME TITLE text-001.
PARAMETERS:p_fname LIKE rlgrap-filename .
SELECTION-SCREEN END OF BLOCK text.
*itab-a = 'A0010000000'.
*APPEND itab.
*itab-a = 'A0010000001'.
*APPEND itab.
*itab-maktx = '测试BDC导入数据'.
*itab-meins = 'BAG'.
*itab-matkl = '100106'.
*
*APPEND itab.
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_fname.
  PERFORM upload USING p_fname .

* START-OF-SELECTION
START-OF-SELECTION.

LOOP AT itab.
    PERFORM append_mm01 USING itab-maktx itab-meins itab-matkl.
    PERFORM run_bdc.
  ENDLOOP.

*---------------------------------------------------------------------*
*       FORM APPEND_DATA_MM01                                         *
*---------------------------------------------------------------------*
*       定义一个子程序里面,用来存放操作的各个步骤                     *
*---------------------------------------------------------------------*
FORM append_mm01 USING fval LIKE itab-maktx
                       fval1 LIKE itab-meins
                       fval2  LIKE itab-matkl.
  CLEAR i_bdcdata.
  CLEAR i_bdcdata[].
*开始新的画面事件
*0173画面
*把程序名字和 BDC DYnpro号码,开始标志 写入内表表头,
  PERFORM bdc_dynpro USING 'SAPLMGMM' '0060'.
  PERFORM bdc_field  USING 'BDC_CURSOR' 'RMMG1-MATNR'.
  PERFORM bdc_field  USING 'BDC_OKCODE' '/00'.
  PERFORM bdc_field  USING 'RMMG1-MATNR' ''.
  PERFORM bdc_field  USING 'RMMG1-MBRSH' 'Z'.
  PERFORM bdc_field  USING 'RMMG1-MTART'  'Z001'.
*开始新的画面事件
  PERFORM bdc_dynpro USING 'SAPLMGMM' '0070'.
  PERFORM bdc_field  USING  'BDC_CURSOR' 'MSICHTAUSW-DYTXT(01)'.
  PERFORM bdc_field  USING  'BDC_OKCODE' '=ENTR'.
  PERFORM bdc_field  USING 'MSICHTAUSW-KZSEL(01)'  'X'.
*开始新的画面事件
  PERFORM bdc_dynpro USING 'SAPLMGMM' '4004'.
  PERFORM bdc_field  USING 'BDC_OKCODE' '=BU'.
  PERFORM bdc_field  USING 'BDC_CURSOR' 'MAKT-MAKTX'.
  PERFORM bdc_field  USING  'MAKT-MAKTX' itab-maktx.
  PERFORM bdc_field  USING 'MARA-MEINS'  itab-meins.
  PERFORM bdc_field  USING  'MARA-MATKkL' itab-matkl.

ENDFORM.                    "APPEND_MM01

*---------------------------------------------------------------------*
*       FORM RUN_BDC                                *
*---------------------------------------------------------------------*
*       ........                                                      *
*---------------------------------------------------------------------*
FORM run_bdc.
*开始调用事务MM01,把做好的bdc对象传递过去,然后把模式设置为A,
*就是说所有窗口,均可以看见.
* N 表示不看见吧
  REFRESH t_bdcmsg.
  CLEAR t_bdcmsg.

CALL TRANSACTION 'MM01' USING i_bdcdata MODE 'N' MESSAGES INTO t_bdcmsg.

READ TABLE t_bdcmsg WITH KEY msgtyp = 'S'
                               msgid = 'M3'
                               msgnr = '800'.
  IF sy-subrc EQ 0.
    CONCATENATE  '物料号:' t_bdcmsg-msgv1  '创建成功' INTO t_log.
  ELSE.
    LOOP AT t_bdcmsg.
      IF t_bdcmsg-msgtyp = 'E'
          OR t_bdcmsg-msgv1 <> ''
          OR t_bdcmsg-msgv2 <> ''
          OR t_bdcmsg-msgv3 <> ''
          OR t_bdcmsg-msgv4 <> ''.
        MESSAGE ID t_bdcmsg-msgid                   "收集错误信息,并写入自定义的表t_log中。
                        TYPE 'S'
                        NUMBER t_bdcmsg-msgnr
                        WITH t_bdcmsg-msgv1
            t_bdcmsg-msgv2
            t_bdcmsg-msgv3
            t_bdcmsg-msgv4
            INTO t_log-information.

CONCATENATE
                                t_bdcmsg-msgv1
*                               itab-posnr
                               '出错:'
                               t_log-information
          INTO t_log-information.
        APPEND t_log.
        CLEAR t_log.
      ENDIF.
    ENDLOOP.
  ENDIF.

LOOP AT t_log.                          "显示出错信息

WRITE:/ t_log-information.

ENDLOOP.

ENDFORM.                    "RUN_BDC
*&---------------------------------------------------------------------*
*&      Form  BDC_DYNPRO
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_0121   text
*      -->P_0122   text
*----------------------------------------------------------------------*
FORM bdc_dynpro  USING    program
                          dynpro.
  i_bdcdata-program = program.
  i_bdcdata-dynpro = dynpro.
  i_bdcdata-dynbegin = 'X'.
  APPEND i_bdcdata.
  CLEAR i_bdcdata.
ENDFORM.                    " BDC_DYNPRO
*&---------------------------------------------------------------------*
*&      Form  BDC_FIELD
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*      -->P_0126   text
*      -->P_0127   text
*----------------------------------------------------------------------*
FORM bdc_field  USING  fnam fval.
  i_bdcdata-fnam = fnam .
  i_bdcdata-fval = fval.
  APPEND i_bdcdata.
  CLEAR i_bdcdata.
ENDFORM.                    " BDC_FIELD
*&---------------------------------------------------------------------*
*&      Form  UPLOAD
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM upload  USING p_fname.
  DATA:cc TYPE i.
  CALL FUNCTION 'WS_FILENAME_GET'
    EXPORTING
      mask             = ',Excel Files,*.xls,All Files,*.*.'(101)
      title            = '选择文件'(100)
    IMPORTING
      filename         = p_fname
    EXCEPTIONS
      inv_winsys       = 1
      no_batch         = 2
      selection_cancel = 3
      selection_error  = 4
      OTHERS           = 5.
  IF sy-subrc <> 0 AND sy-subrc <> 3.
    MESSAGE e398(00) WITH '选择文件出错!'(007).
  ENDIF.

CALL FUNCTION 'ALSM_EXCEL_TO_INTERNAL_TABLE'
    EXPORTING
      filename                = p_fname
      i_begin_col             = 1
      i_begin_row             = 1
      i_end_col               = 100
      i_end_row               = 1000
    TABLES
      intern                  = iexcel
    EXCEPTIONS
      inconsistent_parameters = 1
      upload_ole              = 2
      OTHERS                  = 3.

IF sy-subrc <> 0.
    WRITE:/'文件读入错误!',p_fname.
  ELSE.
    cc = 1.
    LOOP AT iexcel.
      ASSIGN COMPONENT cc  OF
            STRUCTURE itab TO <fs>.

<fs> = iexcel-value(25).
      cc = cc + 1.
      AT END OF row.
        IF iexcel-row <> '0001'.
          APPEND itab.
        ENDIF.
        CLEAR itab.
        cc = 1.
      ENDAT.

ENDLOOP.
  ENDIF.
ENDFORM.                    " UPLOAD

test_bdc的更多相关文章

随机推荐

  1. Linux学习笔记 (二)常用linux命令

    一.命令行语法: 命令字 [选项] [参数] 注意:Linux中对命令是区分大小写的. 二.获取命令帮助: 1.help命令:help xxx,shell内部指令,用来获取linux内部命令.例如:h ...

  2. 网络编程readn、writen和readline函数的编写

    readn   在Linux中,read的声明为: ssize_t read(int fd, void *buf, size_t count); 它的返回值有以下情形: 1.大于0,代表成功读取的字节 ...

  3. myBatis插入oracle获取主键

    <insert id="insert" parameterType="com.inspur.biz.entry.SpLackApply"> < ...

  4. 如何快速复制BAT级的DevOps工具链

    1.流水线改变世界 1910年,福特汽车在引入流水线生产之后,Model-T 的组装时间缩短了8倍,从12.5小时降到了1.5小时,这就是流水线改变世界的神话,造就了汽车上的国家! 那流水线怎么改变软 ...

  5. c#利用委托传递函数参数(1)

    本次旨在解决 同参不同名 的函数作为参数传递的情况 情景: 一下两个函数分别多次重复调用了两个同参不同名的函数(实际上总共有3个这样的函数),函数结构基本相同,只有调用的函数名不一样,显然可以整合在一 ...

  6. 怎样封装RESTful Web Service

    所谓Web Service是一个平台独立的,低耦合的.自包括的.可编程的Web应用程序.有了Web Service异构系统之间就能够通过XML或JSON来交换数据,这样就能够用于开发分布式的互操作的应 ...

  7. linux命令的别名alias,unalias

    1. 别名 linux别名alias的作用: 1. 简化特别长得命令和參数 2. 对一些命令添加默认选项.提高安全性. 2. alias使用 [www@work sh]$ alias lm='ls - ...

  8. Babel中的stage-0,stage-1,stage-2以及stage-3

    大家知道,将ES6代码编译为ES5时,我们常用到Babel这个编译工具.大家参考一些网上的文章或者官方文档,里面常会建议大家在.babelrc中输入如下代码: { "presets" ...

  9. C分配struct变量一个不理解的地方

  10. 【JMeter4.0学习(十一)】之JMeter对(Mysql、Oracle)数据库性能测试脚本开发

    一.MySQL数据库链接: 注:下面所产生的问题一律参考详见:<[JMeter4.0]之遇到的问题总结(持续更新)>(包括Mysql.Orcale) 准备:引包,包路径一定要放对位置,参考 ...