*&---------------------------------------------------------------------*
*& Report  ZMM_03
*&
*&---------------------------------------------------------------------*
*&
*&
*&---------------------------------------------------------------------*

REPORT  ZMM_03 NO STANDARD PAGE HEADING
                       MESSAGE-ID ZMM.
TABLES:MARA.

DATA:BEGIN OF BDCDATA OCCURS 0.
    INCLUDE STRUCTURE BDCDATA.
DATA:END OF BDCDATA.
DATA:   MESSTAB LIKE BDCMSGCOLL OCCURS 0 WITH HEADER LINE.
*DATA: GT_UP LIKE DRAW OCCURS 100 WITH HEADER LINE.
DATA:BEGIN OF GT_UP OCCURS 0.
    INCLUDE STRUCTURE DRAW.
DATA:OLD_DOKNR LIKE DRAW-DOKNR.
DATA:END OF GT_UP.
data: gt_temp like DRAD OCCURS 100 WITH HEADER LINE.
DATA: INPUT TYPE KCDE_INTERN_STRUC OCCURS 100 WITH HEADER LINE.
DATA gt_fieldcat TYPE lvc_t_fcat .
DATA:T_C(2) TYPE C,T_TEMP(20) TYPE C,T_SIGN(1) TYPE C.
DATA: L_MSTRING(480).
DATA: LS_DOKNR LIKE DRAD-DOKNR.
PARAMETERS:MATNR LIKE MARA-MATNR OBLIGATORY.
PARAMETERS:P_MODE TYPE C DEFAULT 'N' NO-DISPLAY.
PARAMETERS: P_LFILE LIKE RLGRAP-FILENAME OBLIGATORY.
PARAMETERS R_INSERT RADIOBUTTON GROUP CTU DEFAULT 'X'.
PARAMETERS R_UPDATE RADIOBUTTON GROUP CTU.
PARAMETERS R_DELETE RADIOBUTTON GROUP CTU.
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_lfile.
 PERFORM GET_FILENAME USING P_LFILE
                       CHANGING P_LFILE.
 START-OF-SELECTION.
 T_SIGN = '3'.
 if p_lfile <> ''.
  PERFORM get_file.
 ENDIF.

IF GT_UP[] IS INITIAL.

ELSE.
****取记录
    PERFORM get_data.

PERform PROCESS_CC02.
    PERform PROCESS_CC03.
    PERform PROCESS_CC04.
    PERFORM PROCESS_CC06.
   IF R_INSERT = 'X'. "新增

T_C = LINES( GT_TEMP ).
      LOOP AT GT_UP.
       T_C = T_C + 1.
       CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = T_C
             IMPORTING
               OUTPUT = T_C.

perform bdc_dynpro      using 'SAPLMGMM' '4300'.
         perform bdc_field       using 'BDC_OKCODE'
                                       '/00'.
         CONCATENATE 'DRAW-DOKNR(' T_C ')' INTO T_TEMP.
         perform bdc_field       using 'BDC_CURSOR'
                                       T_TEMP.
         CONCATENATE 'DRAW-DOKAR(' T_C ')' INTO T_TEMP.
         perform bdc_field       using T_TEMP
                                        GT_UP-DOKAR.
         CONCATENATE 'DRAW-DOKNR(' T_C ')' INTO T_TEMP.
         perform bdc_field       using T_TEMP
                                        GT_UP-DOKNR.
         CONCATENATE 'DRAW-DOKTL(' T_C ')' INTO T_TEMP.
         perform bdc_field       using T_TEMP
                                        GT_UP-DOKTL.
         CONCATENATE 'DRAW-DOKVR(' T_C ')' INTO T_TEMP.
         perform bdc_field       using T_TEMP
                                        GT_UP-DOKVR.
         perform bdc_field       using 'GF_ALLE'
                                       'X'.
*       perform bdc_transaction using 'MM02'.
     ENDLOOP.
     perform bdc_dynpro      using 'SAPLMGMM' '4300'.
     perform bdc_field       using 'BDC_OKCODE'
                                   '=BU'.
     CONCATENATE 'DRAW-DOKVR(' T_C ')' INTO T_TEMP.
     perform bdc_field       using 'BDC_CURSOR'
                                   T_TEMP.
     perform bdc_field       using 'GF_ALLE'
                                   'X'.
  endif.
  IF R_DELETE = 'X'. "删除
      LOOP AT GT_UP.
        LS_DOKNR = GT_UP-DOKNR.
        CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = LS_DOKNR
             IMPORTING
               OUTPUT = LS_DOKNR.
        LOOP AT GT_TEMP WHERE DOKNR = LS_DOKNR.
          T_C = sy-tabix.
        ENDLOOP.
      ENDLOOP.
*       T_C = T_C + 1.
       CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = T_C
             IMPORTING
               OUTPUT = T_C.
       perform bdc_dynpro      using 'SAPLMGMM' '4300'.
       perform bdc_field       using 'BDC_OKCODE'
                                      '=CV140_DELZ'.
       CONCATENATE 'DRAW-DOKAR(' T_C ')' INTO T_TEMP.
       perform bdc_field       using 'BDC_CURSOR'
                                      T_TEMP.
       perform bdc_field       using 'GF_ALLE'
                                      'X'.
      LOOP AT GT_UP.
        LS_DOKNR = GT_UP-DOKNR.
        CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = LS_DOKNR
             IMPORTING
               OUTPUT = LS_DOKNR.
        LOOP AT GT_TEMP WHERE DOKNR = LS_DOKNR.
          T_C = sy-tabix.
        ENDLOOP.
*       T_C = T_C + 1.
       CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = T_C
             IMPORTING
               OUTPUT = T_C.
        CONCATENATE 'MARK(' T_C ')' INTO T_TEMP.
        perform bdc_field       using T_TEMP
                                      'X'.
*        perform bdc_dynpro      using 'SAPLSPO1' '0500'.
*        perform bdc_field       using 'BDC_OKCODE'
*                              '=OPT1'.
     ENDLOOP.
     perform bdc_dynpro      using 'SAPLMGMM' '4300'.
     perform bdc_field       using 'BDC_OKCODE'
                                   '=BU'.
     CONCATENATE 'DRAW-DOKVR(' T_C ')' INTO T_TEMP.
     perform bdc_field       using 'BDC_CURSOR'
                                   T_TEMP.
     perform bdc_field       using 'GF_ALLE'
                                   'X'.
  ENDIF.
  IF R_UPDATE = 'X'. "修改
      LOOP AT GT_UP.
        LS_DOKNR = GT_UP-OLD_DOKNR.
        CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = LS_DOKNR
             IMPORTING
               OUTPUT = LS_DOKNR.
        LOOP AT GT_TEMP WHERE DOKNR = LS_DOKNR.
          T_C = sy-tabix.
        ENDLOOP.
      ENDLOOP.
*       T_C = T_C + 1.
       CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = T_C
             IMPORTING
               OUTPUT = T_C.
       perform bdc_dynpro      using 'SAPLMGMM' '4300'.
       perform bdc_field       using 'BDC_OKCODE'
                                      '=BU'.
       CONCATENATE 'DRAW-DOKNR(' T_C ')' INTO T_TEMP.
       perform bdc_field       using 'BDC_CURSOR'
                                      T_TEMP.
       perform bdc_field       using 'GF_ALLE'
                                      'X'.
      LOOP AT GT_UP.
        LS_DOKNR = GT_UP-OLD_DOKNR.
        CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = LS_DOKNR
             IMPORTING
               OUTPUT = LS_DOKNR.
        LOOP AT GT_TEMP WHERE DOKNR = LS_DOKNR.
          T_C = sy-tabix.
        ENDLOOP.
*       T_C = T_C + 1.
       CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'
             EXPORTING
               INPUT  = T_C
             IMPORTING
               OUTPUT = T_C.
        CONCATENATE 'DRAW-DOKNR(' T_C ')' INTO T_TEMP.
        perform bdc_field       using T_TEMP
                                      GT_UP-DOKNR.
*        perform bdc_dynpro      using 'SAPLSPO1' '0500'.
*        perform bdc_field       using 'BDC_OKCODE'
*                              '=OPT1'.
     ENDLOOP.
     LOOP AT GT_UP.
       perform bdc_dynpro      using 'SAPLSPO1' '0500'.
       perform bdc_field       using 'BDC_OKCODE'
                              '=OPT1'.
     ENDLOOP.
  ENDIF.
*    PERFORM PROCESS_CC07.
  REFRESH MESSTAB.
  CALL TRANSACTION 'MM02' USING BDCDATA MODE P_MODE UPDATE 'S' MESSAGES INTO MESSTAB.
  LOOP AT MESSTAB.
      MESSAGE ID     MESSTAB-MSGID
              TYPE   MESSTAB-MSGTYP
              NUMBER MESSTAB-MSGNR
              INTO L_MSTRING
              WITH MESSTAB-MSGV1
                   MESSTAB-MSGV2
                   MESSTAB-MSGV3
                   MESSTAB-MSGV4.
      IF MESSTAB-MSGTYP = 'E'.
          CONCATENATE MATNR '  ' L_MSTRING INTO L_MSTRING.
      ENDIF.
      WRITE: / MESSTAB-MSGTYP, L_MSTRING(250).
    ENDLOOP.
*  CALL TRANSACTION 'MM02' USING BDCDATA MODE P_MODE UPDATE 'S'.
 endif.
END-OF-SELECTION.

FORM GET_FILENAME   USING  P_PATH    LIKE RLGRAP-FILENAME
                        CHANGING P_FILE  LIKE RLGRAP-FILENAME.
  DATA:L_WRK_FILENAME LIKE RLGRAP-FILENAME,
       L_WRK_MASK     LIKE LGRWO-EXP_FILE.
* mask
  L_WRK_MASK = ',*.xls,*.xls.'.

* get file name
  CALL FUNCTION 'WS_FILENAME_GET'
    EXPORTING
      DEF_PATH         = P_FILE
      MASK             = L_WRK_MASK
      MODE             = 'O'
    IMPORTING
      FILENAME         = L_WRK_FILENAME
    EXCEPTIONS
      INV_WINSYS       = 01
      NO_BATCH         = 02
      SELECTION_CANCEL = 03
      SELECTION_ERROR  = 04
      OTHERS           = 05.

IF SY-SUBRC = 0.
    P_FILE = L_WRK_FILENAME.
  ELSE.
  ENDIF.
ENDFORM.                    " get_filename

FORM get_file.
  CALL FUNCTION 'KCD_EXCEL_OLE_TO_INT_CONVERT'
    EXPORTING
      FILENAME                = P_LFILE
      I_BEGIN_COL             = 1
      I_BEGIN_ROW             = 1
      I_END_COL               = 256
      I_END_ROW               = 65536
    TABLES
      INTERN                  = INPUT
    EXCEPTIONS
      INCONSISTENT_PARAMETERS = 1
      UPLOAD_OLE              = 2
      OTHERS                  = 3.
  IF SY-SUBRC <> 0.
    MESSAGE E000(zqm) WITH '文件路径有误!'.
  ENDIF.

LOOP AT INPUT.
  IF input-row = '0001'.
      CONTINUE.             "第一行是字段名,直接跳过
    ELSE.

CASE INPUT-COL.
          WHEN '0001'.
            GT_UP-DOKAR = INPUT-VALUE.
          WHEN '0002'.
            GT_UP-OLD_DOKNR = INPUT-VALUE.
          WHEN '0003'.
            GT_UP-DOKNR = INPUT-VALUE.
          WHEN '0004'.
            GT_UP-DOKTL = INPUT-VALUE.
          WHEN '0005'.
            GT_UP-DOKVR = INPUT-VALUE.

ENDCASE.

AT END OF ROW.
      APPEND GT_UP.
      CLEAR GT_UP.
    ENDAT.

ENDIF.

ENDLOOP.

*** 检测
  loop at gt_up.
    IF R_INSERT = 'X' OR R_DELETE = 'X'.
      IF GT_UP-OLD_DOKNR = GT_UP-DOKNR.

ELSE.
          WRITE: / '新增,删除,两列文档编号必须一致', SY-SUBRC.
          STOP.
       ENDIF.
    ELSE.
      IF GT_UP-OLD_DOKNR = GT_UP-DOKNR.
        WRITE: / '修改,两列文档编号必须不一致', SY-SUBRC.
          STOP.
       ELSE.

ENDIF.
    ENDIF.
  ENDLOOP.
ENDFORM.

form PROCESS_CC02.
  perform bdc_dynpro      using 'SAPLMGMM' '0060'.
  perform bdc_field       using 'BDC_CURSOR'
                                'RMMG1-MATNR'.
  perform bdc_field       using 'BDC_OKCODE'
                                'ENTR'.
  perform bdc_field       using 'RMMG1-MATNR'
                                matnr.
ENDform. "process_cc02

form PROCESS_CC03.
  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'.
ENDform. "process_cc03

form PROCESS_CC04.
  perform bdc_dynpro      using 'SAPLMGMM' '4004'.
  perform bdc_field       using 'BDC_OKCODE'
                                '=ZU01'.
  perform bdc_field       using 'BDC_CURSOR'
                                'MAKT-MAKTX'.
*  perform bdc_field       using 'MAKT-MAKTX'
*                                'X'.
*  perform bdc_field       using 'MARA-MEINS'
*                                'X'.
*  perform bdc_field       using 'MARA-MATKL'
*                                'X'.
*  perform bdc_field       using 'MARA-EXTWG'
*                                'X'.
*  perform bdc_field       using 'MARA-SPART'
*                                'X'.
*  perform bdc_field       using 'MARA-MTPOS_MARA'
*                                'X'.
*  perform bdc_field       using 'MARA-BRGEW'
*                                'X'.
*  perform bdc_field       using 'MARA-GEWEI'
*                                'X'.
*  perform bdc_field       using 'MARA-NTGEW'
*                                'X'.
*  perform bdc_field       using 'MARA-VOLUM'
*                                'X'.
*  perform bdc_field       using 'MARA-VOLEH'
*                                'X'.
ENDform. "process_cc04

form PROCESS_CC05.
  perform bdc_dynpro      using 'SAPLMGMM' '4300'.
  perform bdc_field       using 'BDC_OKCODE'
                                '=BU'.
  perform bdc_field       using 'BDC_CURSOR'
                                'DRAW-DOKNR(01)'.
  perform bdc_field       using 'DRAW-DOKAR(01)'
                                 GT_UP-DOKAR.
  perform bdc_field       using 'DRAW-DOKNR(01)'
                                 GT_UP-DOKNR.
  perform bdc_field       using 'DRAW-DOKTL(01)'
                                 GT_UP-DOKTL.
  perform bdc_field       using 'DRAW-DOKVR(01)'
                                 GT_UP-DOKVR.
  perform bdc_field       using 'GF_ALLE'
                                'X'.
ENDform. "process_cc05

FORM PROCESS_CC06.
  perform bdc_dynpro      using 'SAPLMGMM' '4300'.
  perform bdc_field       using 'BDC_OKCODE'
                                '=ZU04'.
  perform bdc_field       using 'BDC_CURSOR'
                                'SKTEXT-SPRAS(01)'.
ENDFORM.

FORM PROCESS_CC07.
  perform bdc_dynpro      using 'SAPLMGMM' '4300'.
  perform bdc_field       using 'BDC_OKCODE'
                                '=BU'.
  perform bdc_field       using 'BDC_CURSOR'
                                'DRAW-DOKNR(02)'.
  perform bdc_field       using 'GF_ALLE'
                                'X'.
ENDFORM.

form BDC_DYNPRO USING PROGRAM DYNPRO.
  CLEAR BDCDATA.
  BDCDATA-PROGRAM = PROGRAM.
  BDCDATA-DYNPRO = DYNPRO.
  BDCDATA-DYNBEGIN = 'X'.
  APPEND BDCDATA.
ENDform.

form BDC_FIELD USING FNAM FVAL.
  CLEAR BDCDATA.
  BDCDATA-FNAM = FNAM.
  BDCDATA-FVAL = FVAL.
  APPEND BDCDATA.
ENDform.
*&---------------------------------------------------------------------*
*&      Form  GET_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM GET_DATA .
  select * into CORRESPONDING FIELDS OF TABLE gt_temp
  from DRAD
  where DOKOB = 'MARA' AND
        OBJKY = matnr.

SORT GT_TEMP BY DOKNR.
ENDFORM.                    " GET_DATA

对导入的EXCEL数据批量处理物料文档信息,包括新增,修改,删除

通过BDC批量修改物料文档信息 MM02的更多相关文章

  1. Python之文件处理-批量修改md文档内容

    目录 Python之文件处理-批量修改md文档内容 Python之文件处理-批量修改md文档内容 #!/usr/bin/env python # -*- coding:utf-8 -*- import ...

  2. BDC批量修改物料描述

    一.定义变量 type-POOLs:TRUXS,slis. TYPES: BEGIN OF ty_input , matnr TYPE mara-matnr , " 物料号 maktx TY ...

  3. ERP系统上传文档信息下载(十八)

    下载的公用方法: /// <summary> /// 下载文档 /// </summary> /// <param name="TableName"& ...

  4. Python批量创建word文档(2)- 加图片和表格

    Python创建word文档,任务要求:小杨在一家公司上班,每天都需要给不同的客户发送word文档,以告知客户每日黄金价格.要求在文档开始处给出banner条,价格日期等用表格表示.最后贴上自己的联系 ...

  5. 批量删除wps文档里的回车符的方法!WPS使用技巧分享!

    有时候整理文档的时候,如果是从网上复制的文字,可能会因为复制而产生很多的回车符.怎样能批量去掉这些个回车符呢,下面马上告诉你批量删除wps文档里的回车符的方法!WPS使用技巧分享! 想要批量删除批量删 ...

  6. C# 导出word文档及批量导出word文档(1)

         这里用到了两个dll,一个是aspose.word.dll,另外一个是ICSharpCode.SharpZipLib.dll,ICSharpCode.SharpZipLib.dll是用于批量 ...

  7. Dom4j修改xml文档

    1. 写出内容到xml文档 XMLWriter writer = new XMLWriter(OutputStream, OutputForamt) wirter.write(Document); 2 ...

  8. C# 导出word文档及批量导出word文档(4)

          接下来是批量导出word文档和批量打印word文件,批量导出word文档和批量打印word文件的思路差不多,只是批量打印不用打包压缩文件,而是把所有文件合成一个word,然后通过js来调用 ...

  9. 怎么修改PDF文档图片内容

    我们想要修改PDF文件的时候应该怎么做呢,PDF文件不同于其他的文件,PDF文件的编辑需要借助PDF编辑器才能够对文件进行编辑修改,那么要怎么修改PDF文档图片内容呢,有许多的小伙伴都想知道该怎么做, ...

随机推荐

  1. 自学Python-基于tcp协议的socket

    自学Python之路-Python基础+模块+面向对象自学Python之路-Python网络编程自学Python之路-Python并发编程+数据库+前端自学Python之路-django 自学Pyth ...

  2. 个人小应用服务器安装搭建,HP 360p Gen9 使用winpe安装centos[一]

    以前用aws的时候使用的ec2, 里面可选的windows server搭配umbraco的cms做了自己的个人网站,主要是当年项目需要,使用aws,我也办了国际币种卡,在组里各种联系亚马逊开服务,后 ...

  3. PHP5.3x被弃用的函数及代替方法

    今天阳光明媚,万里无云,小记一下php5.3x被弃用的部分函数及代替方法 下面列举了部分被弃用的函数:call_user_method():(使用 call_user_func() 替代)call_u ...

  4. BZOJ1791 基环树直径

    非递归版4S /************************************************************** Problem: 1791 User: 18357 Lan ...

  5. 【CF208E】Blood Cousins

    题目大意:给定一个 N 个点的森林,M 个询问,每次询问对于点 u 来说,有多少个点和 u 有相同的 K 级祖先. 题解:线段树合并适合处理子树贡献的问题. 发现要回答这个询问在点 u 处计算很困难, ...

  6. CentOS下nagios报警飞信部署四步走

    CentOS下nagios报警飞信部署四步走   今天 帮群里一兄弟配了下nagios上的飞信,这个东西 我个人感觉还是很实用的,不过好久没配了,今天配置了一遍,顺便 就把过程记录下来了,供大家学习! ...

  7. php面向对象相关技术

    step1 一个经典类的设计和实例化 <?php class mycoach { public $_name=''; public $_age=''; public $_expert=array ...

  8. qt5---滑动条QSlider

    需要    #include <QSlider> #include "win.h" #include <QDebug> #include <QPush ...

  9. Hibernate 缓存机制详细分析

    在本篇随笔里将会分析一下hibernate的缓存机制,包括一级缓存(session级别).二级缓存(sessionFactory级别)以及查询缓存,当然还要讨论下我们的N+1的问题. 随笔虽长,但我相 ...

  10. Python 异常处理Ⅲ

    使用except而不带任何异常类型 你可以不带任何异常类型使用except,如下实例: 以上方式try-except语句捕获所有发生的异常.但这不是一个很好的方式,我们不能通过该程序识别出具体的异常信 ...