SAP R/3 форум ABAP консультантов
Russian ABAP Developer's Club

Home - FAQ - Search - Memberlist - Usergroups - Profile - Log in to check your private messages - Register - Log in - English
Blogs - Weblogs News

вывод несторнированных документов материала



 
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP
View previous topic :: View next topic  
Author Message
livur
Участник
Участник



Joined: 27 Mar 2008
Posts: 4
Location: moscow region

PostPosted: Thu Mar 27, 2008 7:24 am    Post subject: вывод несторнированных документов материала Reply with quote

*интересует создание инфо-набора вывода всех несторнированных документов материала
Back to top
View user's profile Send private message
vga
Мастер
Мастер


Age: 165
Joined: 04 Oct 2007
Posts: 1218
Location: Санкт-Петербург

PostPosted: Thu Mar 27, 2008 10:52 am    Post subject: Reply with quote

Документ сторнирован полностью или частично, если существует другой документ, ссылающийся на исходный через поля
MSEG-SMBLN = MSEG-MBLNR
MSEG-SJAHR = MSEG-MJAHR
MSEG-SMBLP = MSEG-ZEILE

Список сторнирующих документов виден в вьюхе M_MBMPS

Для примера кусок кода

Code:
*----------------------------------------------------------------------*
*   INCLUDE                                    *
*----------------------------------------------------------------------*
TYPE-POOLS: vrm.

TABLES: mseg, mbew, t001k, t001, bsim, ska1, t134m,
        marv, t030r, t030, t156t, skat.

CONSTANTS: c_ja    VALUE 'X',
           c_nein  VALUE ' ',
           null  TYPE c VALUE '0'.

*types
TYPES: BEGIN OF t_mbew,
        matnr LIKE mbew-matnr,
        bwkey LIKE mbew-bwkey,
        bklas LIKE mbew-bklas,
      END OF t_mbew.

TYPES: BEGIN OF imrep_organ_typ,
         mandt LIKE t001-mandt,
         bukrs LIKE t001-bukrs,
         butxt LIKE t001-butxt,
         waers LIKE t001-waers,
         ktopl LIKE t001-ktopl,
         lfgja LIKE marv-lfgja,
         lfmon LIKE marv-lfmon,
         vmgja LIKE marv-vmgja,
         vmmon LIKE marv-vmmon,
         vjgja LIKE marv-vjgja,
         vjmon LIKE marv-vjmon,
         bwkey LIKE t001k-bwkey,
         bwmod LIKE t001k-bwmod,
         xvkbw LIKE t001k-xvkbw,  " Kennzeichen: Verkaufspreisbew. aktiv
         werks LIKE t001w-werks,
         name1 LIKE t001w-name1,
         lgort LIKE t001l-lgort,
         lgobe LIKE t001l-lgobe,
       END OF imrep_organ_typ.

TYPES: BEGIN OF t030_typ.
        INCLUDE STRUCTURE t030.
TYPES:   txt50 LIKE skat-txt50,
         xkomo LIKE t030r-xkomo,
         xbwmo LIKE t030r-xbwmo,
         xbkla LIKE t030r-xbkla,
         xdiko LIKE t030r-xdiko.
TYPES: END OF t030_typ.

TYPES: BEGIN OF mbew_typ,
         mandt   LIKE mbew-mandt,
         matnr   LIKE mbew-matnr,
         bwkey   LIKE mbew-bwkey,
         bwtar   LIKE mbew-bwtar,
         lvorm   LIKE mbew-lvorm,
         lbkum   LIKE mbew-lbkum,
*  field size extended                                      "n497391
         salk3(10)           TYPE p    DECIMALS 2,          "n497391
         vprsv   LIKE mbew-vprsv,
         verpr   LIKE mbew-verpr,
         stprs   LIKE mbew-stprs,
         peinh   LIKE mbew-peinh,
         bklas   LIKE mbew-bklas,
         salkv   LIKE mbew-salkv,
         lfgja   LIKE mbew-lfgja,
         lfmon   LIKE mbew-lfmon,
         bwtty   LIKE mbew-bwtty,
         pstat   LIKE mbew-pstat,
         vksal   LIKE mbew-vksal,
         eklas   LIKE mbew-eklas,
         qklas   LIKE mbew-qklas,
         sobkz   LIKE ebew-sobkz,
         vbeln   LIKE ebew-vbeln,
         posnr   LIKE ebew-posnr,
         pspnr   LIKE qbew-pspnr,
         bukrs   LIKE t001-bukrs,
         butxt   LIKE t001-butxt,
         xkonto  LIKE ska1-saknr,
         lifnr               LIKE      obew-lifnr,          "n497391
         ke_xwart TYPE c,              " Wertartikel: Verkaufswert
         xvkbw   LIKE t001k-xvkbw,
         no_sum  TYPE c.
TYPES: END OF mbew_typ.

*ranges
RANGES: r_matnr FOR mseg-matnr,
        r_gjahr FOR mseg-gjahr,
        r_bwkey FOR mbew-bwkey,
        r_budat FOR bkpf-budat,
        r_bwart FOR mseg-bwart,
        r_bwart2 FOR mseg-bwart,
        ibklas  FOR mbew-bklas,
        so_bukrs_save FOR t001-bukrs.

*data
DATA: BEGIN OF it_t001 OCCURS 0,
      bukrs TYPE t001-bukrs,
      END OF it_t001.

DATA: BEGIN OF xmarav OCCURS 0,
        matnr LIKE marav-matnr,
        mtart LIKE marav-mtart,
        lvorm LIKE marav-lvorm,
        meins LIKE marav-meins,
        maktx LIKE marav-maktx.
DATA: END OF xmarav.

DATA:   rc      LIKE sy-subrc,
        xkonto  LIKE ska1-saknr.   "Sachkonto
DATA: xmbew   TYPE mbew_typ        OCCURS 0 WITH HEADER LINE.
DATA: BEGIN OF material OCCURS 0,
        matnr LIKE xmbew-matnr,
      END OF material,

    BEGIN OF it_bsim OCCURS 0,
      matnr LIKE bsim-matnr,
      bwkey LIKE bsim-bwkey,
      bwtar LIKE bsim-bwtar,
      dmbtr LIKE bsim-dmbtr,
      menge LIKE bsim-menge,
      meins LIKE bsim-meins,
      shkzg LIKE bsim-shkzg,
      budat LIKE bkpf-budat,
      xauto LIKE mseg-xauto,
*      bustm LIKE mseg-bustm,
*      insmk LIKE mseg-insmk,
      bwart LIKE mseg-bwart,
      ebeln LIKE mseg-ebeln,
      ebelp LIKE mseg-ebelp,
      mblnr LIKE mseg-mblnr,
      mjahr LIKE mseg-mjahr,
      zeile LIKE mseg-zeile,
      sjahr LIKE mseg-sjahr,
      smbln LIKE mseg-smbln,
      smblp LIKE mseg-smblp,
      elikz LIKE mseg-elikz,
      belnr LIKE bsim-belnr,
      gjahr LIKE bsim-gjahr,
      buzei LIKE bsim-buzei,
    END OF it_bsim,

    BEGIN OF itab_res OCCURS 0,
      bwkey LIKE bsim-bwkey,
      bwtar LIKE bsim-bwtar,
      konto LIKE ska1-saknr,
      matnr LIKE mseg-matnr,
      menge LIKE mseg-menge,
      meins LIKE mseg-meins,
      dmbtr LIKE ckps-wertb,
      waers LIKE mseg-waers,

      menge_1 LIKE mseg-menge,
      meins_1 LIKE mseg-meins,
      dmbtr_1 LIKE ckps-wertb,
      waers_1 LIKE mseg-waers,
      menge_2 LIKE mseg-menge,
      meins_2 LIKE mseg-meins,
      dmbtr_2 LIKE ckps-wertb,
      waers_2 LIKE mseg-waers,
      menge_3 LIKE mseg-menge,
      meins_3 LIKE mseg-meins,
      dmbtr_3 LIKE ckps-wertb,
      waers_3 LIKE mseg-waers,
      menge_4 LIKE mseg-menge,
      meins_4 LIKE mseg-meins,
      dmbtr_4 LIKE ckps-wertb,
      waers_4 LIKE mseg-waers,

    END OF itab_res.

* AVL data
DATA: wa_res LIKE itab_res. " For double_click
DATA: message_text(40) TYPE c,
      index_z       LIKE sy-tabix.

DATA: BEGIN OF x030_key,
        mandt LIKE sy-mandt,
        ktopl LIKE t030-ktopl,
        ktosl LIKE t030-ktosl,
        bwmod LIKE t030-bwmod,
        komok LIKE t030-komok,
        bklas LIKE t030-bklas.
DATA: END OF x030_key.

DATA: BEGIN OF organ OCCURS 0.                     "note 358829
INCLUDE     TYPE imrep_organ_typ.         "note 358829
DATA: xbkla LIKE t030r-xbkla.             "note 358829
DATA: END OF organ.                                "note 358829

DATA: it030   TYPE t030_typ        OCCURS 0 WITH HEADER LINE.

DATA: alv_grid TYPE REF TO cl_gui_alv_grid,
     container TYPE REF TO cl_gui_custom_container,
     dt TYPE TABLE OF lvc_t_data,
     gt_alv_fieldcat  TYPE slis_t_fieldcat_alv,
     gt_lvc_fcat      TYPE lvc_t_fcat,
     gl_lvc_fcat      TYPE lvc_s_fcat,
     gt_sort          TYPE lvc_t_sort,
     g_layo           TYPE lvc_s_layo.

TYPES:
      ty_matnrrange TYPE RANGE OF mseg-matnr,
      BEGIN OF ty_bwkeyrange,
        bukrs      TYPE bukrs,
        range      TYPE RANGE OF bsim-bwkey,
      END   OF ty_bwkeyrange,

*     Material ledger data
      BEGIN OF ty_ckml,
        matnr  TYPE ckmlhd-matnr,
        bwkey  TYPE ckmlhd-bwkey,
        bwtar  TYPE ckmlhd-bwtar,
*        vbeln  TYPE ckmlhd-vbeln,
*        posnr  TYPE ckmlhd-posnr,
        pspnr  TYPE ckmlhd-pspnr,
        kalnr  TYPE ckmlhd-kalnr,
        waers  TYPE ckmlcr-waers,
        salk3  TYPE ckmlcr-salk3,
        bdatj  TYPE ckmlcr-bdatj,
        bpoper TYPE ckmlcr-poper,
      END OF ty_ckml,

      BEGIN OF ty_bsis,
        bukrs    TYPE bsis-bukrs,
        belnr    TYPE bsis-belnr,
        gjahr    TYPE bsis-gjahr,
        buzei    TYPE bsis-buzei,
        amount   TYPE bsis-wrbtr,
*        wrbtr    TYPE bsis-wrbtr,
*        dmbe2    TYPE bsis-dmbe2,
*        dmbe3    TYPE bsis-dmbe3,
*        shkzg    TYPE bsis-shkzg,
      END   OF ty_bsis,

      BEGIN OF ty_currency,
        number     TYPE i,
        cc_curtp   TYPE curtp,  "Currency type from company code
        ml_curtp   TYPE curtp,  "Currency type from material ledger
        waers      TYPE waers,  "Currency
      END OF ty_currency.


DATA:
      it_currency    TYPE TABLE OF ty_currency,
      wa_currency    TYPE ty_currency,
      it_bwkeytable  TYPE TABLE OF ty_bwkeyrange,
      wa_bwkeytable  TYPE ty_bwkeyrange,
      it_rangestable TYPE TABLE OF ty_matnrrange,
      it_ckml        TYPE TABLE OF ty_ckml,
      it_ckmlcr      TYPE TABLE OF ckmlcr,
*      it_bsis        TYPE SORTED TABLE OF ty_bsis
*                          WITH NON-UNIQUE KEY bukrs belnr gjahr buzei,
      it_bsis        TYPE TABLE OF ty_bsis
                          WITH NON-UNIQUE KEY belnr gjahr buzei,
*                          WITH HEADER LINE,
      g_bwkeyrange   TYPE RANGE OF bsim-bwkey,
      wa_bwkeyrange  LIKE LINE OF g_bwkeyrange,

      g_curtp        TYPE curtp,
      g_multicurr    TYPE char1,
      g_currency_num TYPE i,
      g_err_msg(100) TYPE c.

FIELD-SYMBOLS:
      <fs_matnrrange>  TYPE ty_matnrrange,
      <fs_bwkeytable>  TYPE ty_bwkeyrange,
      <fs-ckml>        TYPE ty_ckml,
      <fs_currency>    TYPE ty_currency,
      <fs_bsis>        TYPE ty_bsis.

DATA: t_curtp_dropdown TYPE vrm_values.
DATA: f_curtp_dropdown TYPE vrm_value.

CONSTANTS:
      c_init_currency  TYPE waers VALUE 'CRU'.
CONSTANTS:
      c_tcode          TYPE sy-tcode VALUE 'ZE_MB_TURNOVER'.

TYPES:
*      ty_hkontrange TYPE RANGE OF bsis-hkont,
*     Type of bsim for values
      BEGIN OF ty_bsim_belnr,
        matnr LIKE bsim-matnr,
        bwkey LIKE bsim-bwkey,
        bwtar LIKE bsim-bwtar,
*        dmbtr LIKE bsim-dmbtr,
        shkzg LIKE bsim-shkzg,
*        budat LIKE bkpf-budat,
*        belnr LIKE bsim-belnr,
*        gjahr LIKE bsim-gjahr,
*        buzei LIKE bsim-buzei,
  dmbtr LIKE bsim-dmbtr,

      END OF ty_bsim_belnr,

*     Type of bsim for quantities
      BEGIN OF ty_bsim_mblnr,
        matnr LIKE bsim-matnr,
        bwkey LIKE bsim-bwkey,
        bwtar LIKE bsim-bwtar,
        menge LIKE bsim-menge,
        meins LIKE bsim-meins,
        shkzg LIKE bsim-shkzg,
        budat LIKE bkpf-budat,
        bwart LIKE mseg-bwart,
        xauto LIKE mseg-xauto,
        ebeln LIKE mseg-ebeln,
        ebelp LIKE mseg-ebelp,
        elikz LIKE mseg-elikz,
        mblnr LIKE mseg-mblnr,
        mjahr LIKE mseg-mjahr,
        zeile LIKE mseg-zeile,
        sjahr LIKE mseg-sjahr,
        smbln LIKE mseg-smbln,
        smblp LIKE mseg-smblp,
      END OF ty_bsim_mblnr.

DATA:
       wa_fieldstab(72) TYPE c,
       it_selecttab     LIKE TABLE OF wa_fieldstab,
       it_grouptab      LIKE TABLE OF wa_fieldstab,
       l_low_date       TYPE bkpf-budat,
       l_high_date      TYPE bkpf-budat,
       bsim_mblnr_tmp   TYPE ty_bsim_mblnr.

DATA:
*     Internal tables with material amounts
*     1. Amounts for current bukrs (in cycle) - In selected Period
      it_bsim_belnr_bukrs_ip TYPE TABLE OF ty_bsim_belnr,
*     2. Amounts for current bukrs (in cycle) - Post Period
      it_bsim_belnr_bukrs_pp TYPE TABLE OF ty_bsim_belnr,
*     3. Amounts In selected Period
      it_bsim_belnr_ip       TYPE TABLE OF ty_bsim_belnr,
*     2. Amounts - Post Period
      it_bsim_belnr_pp       TYPE TABLE OF ty_bsim_belnr,

*     Internal tables with material quantities
      it_bsim_mblnr          TYPE TABLE OF ty_bsim_mblnr
                                  WITH HEADER LINE.


SELECTION-SCREEN BEGIN OF BLOCK abgrenzung WITH FRAME TITLE text-001.
SELECT-OPTIONS:
      s_matnr  FOR mbew-matnr  MATCHCODE OBJECT mat1
                             MEMORY ID mat,
      s_bukrs  FOR t001k-bukrs MEMORY ID buk,
      s_bwkey  FOR t001k-bwkey MEMORY ID bwk,
      s_bwtar  FOR mbew-bwtar  MEMORY ID bwt,
      s_bklas  FOR mbew-bklas,
      s_skont  FOR ska1-saknr.

SELECTION-SCREEN BEGIN OF LINE.
SELECTION-SCREEN COMMENT 1(24) text-003.
SELECTION-SCREEN POSITION 33.
PARAMETERS p_monat LIKE bkpf-monat DEFAULT sy-datum+4(2).
SELECTION-SCREEN POSITION 36.
PARAMETERS p_gjahr LIKE mseg-mjahr DEFAULT sy-datum(4).
SELECTION-SCREEN COMMENT 52(2) text-004.
SELECTION-SCREEN POSITION 58.
PARAMETERS p_monat2 LIKE bkpf-monat DEFAULT sy-datum+4(2).
SELECTION-SCREEN POSITION 61.
PARAMETERS p_gjahr2 LIKE mseg-mjahr DEFAULT sy-datum(4).
SELECTION-SCREEN END OF LINE.

SELECTION-SCREEN END OF BLOCK abgrenzung.

SELECTION-SCREEN BEGIN OF BLOCK umfang WITH FRAME TITLE text-051.
PARAMETERS:
            nullb   LIKE am07m-senul,     " Materialien mit Nullbestand
            keinzel LIKE am07m-kgebe.     " Bewertungskreisebene

SELECTION-SCREEN END OF BLOCK umfang.

START-OF-SELECTION.

    REFRESH s_bukrs.
    INSERT LINES OF so_bukrs_save INTO TABLE s_bukrs.
    PERFORM organisation.
    DATA: l_poper LIKE t009b-poper.
*calculating first and last periods
    MOVE 'I'  TO r_gjahr-sign.
    MOVE 'BT' TO r_gjahr-option.
    MOVE p_gjahr TO r_gjahr-low.
    MOVE p_gjahr2 TO r_gjahr-high.
    APPEND r_gjahr.

    CALL FUNCTION 'T001_READ'
         EXPORTING
              bukrs  = s_bukrs-low
         IMPORTING
              struct = t001.

    CLEAR r_budat-low.
    l_poper = p_monat.
    CALL FUNCTION 'FIRST_DAY_IN_PERIOD_GET'
         EXPORTING
              i_gjahr        = p_gjahr
              i_periv        = t001-periv
              i_poper        = l_poper
         IMPORTING
              e_date         = r_budat-low
         EXCEPTIONS
              input_false    = 1
              t009_notfound  = 1
              t009b_notfound = 1.
    IF sy-subrc <> 0.
      MESSAGE s000(zeruxx_gc) WITH text-005.
      EXIT.
    ENDIF.

    CLEAR r_budat-high.
    l_poper = p_monat2.
    CALL FUNCTION 'LAST_DAY_IN_PERIOD_GET'
         EXPORTING
              i_gjahr        = p_gjahr2
              i_periv        = t001-periv
              i_poper        = l_poper
         IMPORTING
              e_date         = r_budat-high
         EXCEPTIONS
              input_false    = 1
              t009_notfound  = 1
              t009b_notfound = 1.
    IF sy-subrc <> 0.
      MESSAGE s000(zeruxx_gc) WITH text-006.
      EXIT.
    ENDIF.

    MOVE 'I'  TO r_budat-sign.
    MOVE 'BT' TO r_budat-option.
    APPEND r_budat.

    MOVE 'I'  TO r_bwkey-sign.
    MOVE 'EQ' TO r_bwkey-option.
    LOOP AT organ.
      r_bwkey-low = organ-bwkey.
      COLLECT r_bwkey.
    ENDLOOP.

*1. Getting FI parameters
    CLEAR xmbew.                                            "388498
    SELECT mandt matnr bwkey bwtar lvorm lbkum salk3
           vprsv verpr stprs peinh bklas salkv lfgja lfmon
           bwtty pstat vksal eklas qklas
           FROM mbew INTO CORRESPONDING FIELDS OF xmbew
           FOR ALL ENTRIES IN organ WHERE bwkey EQ organ-bwkey
                                    AND   matnr IN s_matnr
                                    AND   bwtar IN s_bwtar
                                    AND   bklas IN s_bklas.
      CHECK NOT xmbew-bklas IS INITIAL.
      APPEND xmbew.
    ENDSELECT.
    CLEAR xmbew.                                            "388498
    SELECT mandt matnr bwkey bwtar lbkum salk3
           vprsv verpr stprs peinh bklas salkv lfgja lfmon
           bwtty vksal sobkz vbeln posnr
           FROM ebew INTO CORRESPONDING FIELDS OF xmbew
           FOR ALL ENTRIES IN organ WHERE bwkey EQ organ-bwkey
                                    AND   matnr IN s_matnr
                                    AND   bwtar IN s_bwtar
                                    AND   bklas IN s_bklas.
      CHECK NOT xmbew-bklas IS INITIAL.
      xmbew-no_sum = 'X'.
      APPEND xmbew.
    ENDSELECT.
    CLEAR xmbew.                                            "388498
    SELECT mandt matnr bwkey bwtar lbkum salk3
           vprsv verpr stprs peinh bklas salkv lfgja lfmon
           bwtty vksal sobkz pspnr
           FROM qbew INTO CORRESPONDING FIELDS OF xmbew
           FOR ALL ENTRIES IN organ WHERE bwkey EQ organ-bwkey
                                    AND   matnr IN s_matnr
                                    AND   bwtar IN s_bwtar
                                    AND   bklas IN s_bklas.
      CHECK NOT xmbew-bklas IS INITIAL.
      xmbew-no_sum = 'X'.
      APPEND xmbew.
    ENDSELECT.

*       consider valuated subcontractor stocks from OBEW    "n497391
    CLEAR xmbew.                                            "n497391
    SELECT mandt matnr bwkey bwtar lbkum salk3              "n497391
           vprsv verpr stprs peinh bklas salkv              "n497391
           lfgja lfmon bwtty vksal sobkz lifnr              "n497391
           FROM obew INTO CORRESPONDING FIELDS OF xmbew     "n497391
           FOR ALL ENTRIES IN organ                         "n497391
           WHERE  bwkey EQ organ-bwkey                      "n497391
             AND  matnr IN s_matnr                          "n497391
             AND  bwtar IN s_bwtar                          "n497391
             AND  bklas IN s_bklas.                         "n497391
      CHECK NOT xmbew-bklas IS INITIAL.                     "n497391
      xmbew-no_sum = 'X'.                                   "n497391
      APPEND xmbew.                                         "n497391
    ENDSELECT.                                              "n497391

    IF xmbew[] IS INITIAL.
      MESSAGE s002(zeruxx_gc).
      EXIT.
    ENDIF.

* Lesen des Materialstammes:
    CLEAR r_matnr.
    MOVE 'I'  TO r_matnr-sign.
    MOVE 'EQ' TO r_matnr-option.
    LOOP AT xmbew.
      MOVE xmbew-matnr TO material-matnr.
      COLLECT material.
      MOVE xmbew-matnr TO r_matnr-low.
      COLLECT r_matnr.
    ENDLOOP.

* For every material we need the material master MARA. If the
* logon language is present in MAKT, we also need the text.
* INNER JOIN or OUTER JOIN cannot be used because the language-condition
* canot be handled in one statement.
    SELECT matnr mtart lvorm meins                          "353378
           INTO CORRESPONDING FIELDS OF TABLE xmarav        "353378
           FROM mara                                        "353378
           FOR ALL ENTRIES IN material                      "353378
           WHERE matnr = material-matnr.                    "353378

    PERFORM selektion_bearbeiten.

    SORT xmbew BY matnr bwkey bwtar.
    LOOP AT xmbew.
      IF NOT keinzel IS INITIAL OR xmbew-bwtty IS INITIAL.
        CHECK xmbew-bwtar IS INITIAL.
      ELSEIF keinzel IS INITIAL AND NOT xmbew-bwtty IS INITIAL.
        CHECK NOT xmbew-bwtar IS INITIAL.
      ENDIF.
      READ TABLE xmarav WITH KEY matnr = xmbew-matnr BINARY SEARCH.
      IF sy-subrc IS INITIAL.
        itab_res-meins = xmarav-meins.
        itab_res-meins_1 = xmarav-meins.
        itab_res-meins_2 = xmarav-meins.
        itab_res-meins_3 = xmarav-meins.
        itab_res-meins_4 = xmarav-meins.
      ENDIF.
      READ TABLE organ WITH KEY mandt = sy-mandt
                                  bwkey = xmbew-bwkey BINARY SEARCH.
      IF sy-subrc IS INITIAL.
        itab_res-waers = organ-waers.
        itab_res-waers_1 = organ-waers.
        itab_res-waers_2 = organ-waers.
        itab_res-waers_3 = organ-waers.
        itab_res-waers_4 = organ-waers.
      ENDIF.

      itab_res-bwkey = xmbew-bwkey.
      itab_res-bwtar = xmbew-bwtar.
      itab_res-konto = xmbew-xkonto.
      itab_res-matnr = xmbew-matnr.
      itab_res-menge_4 = xmbew-lbkum.
      itab_res-dmbtr_4 = xmbew-salk3.
      itab_res-menge = itab_res-menge_4.
      itab_res-dmbtr = itab_res-dmbtr_4.
      COLLECT itab_res.
    ENDLOOP.

    MESSAGE s000(zeruxx_gc) WITH text-m01 INTO sy-msgli.
    CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
         EXPORTING
              text = sy-msgli.

* otherwise
* here get only amount
    SELECT  matnr bwkey
            bwtar dmbtr
            shkzg budat
      FROM bsim
      APPENDING CORRESPONDING FIELDS OF TABLE it_bsim
      WHERE matnr IN r_matnr
        AND bwkey IN r_bwkey
        AND bwtar IN s_bwtar
        AND budat >= r_budat-low.

* here get only quantity
    MESSAGE s000(zeruxx_gc) WITH text-m03 INTO sy-msgli.
    CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
         EXPORTING
              text = sy-msgli.

    SELECT  i~matnr i~werks AS bwkey
      i~bwtar i~menge i~meins
      i~shkzg h~budat i~bwart i~xauto
      i~ebeln i~ebelp i~elikz
      i~mblnr i~mjahr i~zeile
      i~sjahr i~smbln i~smblp
      FROM mseg AS i
      INNER JOIN mkpf AS h ON h~mblnr = i~mblnr
                          AND h~mjahr = i~mjahr
      APPENDING CORRESPONDING FIELDS OF TABLE it_bsim
      WHERE i~matnr IN r_matnr

        AND i~werks IN r_bwkey
        AND h~budat >= r_budat-low.

* exclude transfer movement
    CLEAR r_bwart.
    MOVE 'I'  TO r_bwart-sign.
    MOVE 'EQ' TO r_bwart-option.
    SELECT * FROM t156t WHERE spras = 'E'.
      IF t156t-btext(2) EQ 'TR' OR t156t-btext(2) EQ 'TF'.
        r_bwart-low = t156t-bwart.
        COLLECT r_bwart.
      ENDIF.
    ENDSELECT.

* here get only quantity
    MESSAGE s000(zeruxx_gc) WITH text-m04 INTO sy-msgli.
    CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
         EXPORTING
              text = sy-msgli.

    DATA: bsim_tmp LIKE it_bsim,
         tabix_tmp LIKE sy-tabix.
    SORT itab_res BY matnr bwkey bwtar.
    SORT it_bsim BY ebeln ebelp elikz sjahr smbln smblp.

    LOOP AT it_bsim.

      IF NOT it_bsim-ebeln IS INITIAL AND
             it_bsim-bwart IN r_bwart.

        bsim_tmp = it_bsim.
        tabix_tmp = sy-tabix.
* search document "Delivery completed" indicator
        READ TABLE it_bsim WITH KEY ebeln = bsim_tmp-ebeln
                             ebelp = bsim_tmp-ebelp
                             elikz = 'X' BINARY SEARCH.
        IF sy-subrc IS INITIAL.
* test "Delivery completed" document did't canceled
          READ TABLE it_bsim WITH KEY ebeln = it_bsim-ebeln
                             ebelp = it_bsim-ebelp
                             elikz = ''
                             sjahr = it_bsim-mjahr
                             smbln = it_bsim-mblnr
                             smblp = it_bsim-zeile
                             BINARY SEARCH.
          CHECK sy-subrc IS INITIAL.
*        IF NOT SY-SUBRC IS INITIAL.
*          IF bsim_tmp-xauto = 'X' AND (
*            bsim_tmp-bwart EQ '301' OR
*            bsim_tmp-bwart EQ '302' ).
*              BREAK-POINT.
*            ELSE.
*              CONTINUE.
*          ENDIF.
*        ENDIF.
        ENDIF.
        sy-tabix = tabix_tmp.
        it_bsim = bsim_tmp.
      ENDIF.

      CLEAR itab_res.
      READ TABLE itab_res WITH KEY matnr = it_bsim-matnr
                             bwkey = it_bsim-bwkey
                             bwtar = it_bsim-bwtar
                             BINARY SEARCH.
      CHECK sy-subrc IS INITIAL.
      IF it_bsim-budat > r_budat-high.
        IF it_bsim-shkzg EQ 'H'.
          itab_res-menge_4 = itab_res-menge_4 + it_bsim-menge.
          itab_res-dmbtr_4 = itab_res-dmbtr_4 + it_bsim-dmbtr.
        ELSE.
          itab_res-menge_4 = itab_res-menge_4 - it_bsim-menge.
          itab_res-dmbtr_4 = itab_res-dmbtr_4 - it_bsim-dmbtr.
        ENDIF.
      ELSE.
        IF it_bsim-shkzg EQ 'H'.
          itab_res-menge_2 = itab_res-menge_2 + it_bsim-menge.
          itab_res-dmbtr_2 = itab_res-dmbtr_2 + it_bsim-dmbtr.
          itab_res-menge_3 = itab_res-menge_3 - it_bsim-menge.
          itab_res-dmbtr_3 = itab_res-dmbtr_3 - it_bsim-dmbtr.
        ELSE.
          itab_res-menge_1 = itab_res-menge_1 + it_bsim-menge.
          itab_res-dmbtr_1 = itab_res-dmbtr_1 + it_bsim-dmbtr.
          itab_res-menge_3 = itab_res-menge_3 + it_bsim-menge.
          itab_res-dmbtr_3 = itab_res-dmbtr_3 + it_bsim-dmbtr.
        ENDIF.
      ENDIF.
      itab_res-menge = itab_res-menge_4 - itab_res-menge_3.
      itab_res-dmbtr = itab_res-dmbtr_4 - itab_res-dmbtr_3.

      MODIFY itab_res INDEX sy-tabix.
    ENDLOOP.

    IF nullb IS INITIAL.
* delete zero stock
      MESSAGE s000(zeruxx_gc) WITH text-m05 INTO sy-msgli.
      CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
           EXPORTING
                text = sy-msgli.

      DELETE itab_res
        WHERE menge IS initial
        AND   menge_1 IS initial
        AND   menge_2 IS initial
        AND   menge_3 IS initial
        AND   menge_4 IS initial.
    ENDIF.

    PERFORM write_to_alv TABLES itab_res.
    CALL SCREEN 9000.



Last edited by vga on Mon Mar 31, 2008 1:02 pm; edited 2 times in total
Back to top
View user's profile Send private message Blog Visit poster's website
livur
Участник
Участник



Joined: 27 Mar 2008
Posts: 4
Location: moscow region

PostPosted: Thu Mar 27, 2008 4:22 pm    Post subject: по заказчику вывести номера НЕсторнированных ДМ Reply with quote

спасибо
подскажите, пожалуйста, кусок кода, в котором будет выведены только номера Несторнированных ДМ
Back to top
View user's profile Send private message
Удав
Гуру
Гуру


Age: 48
Joined: 25 Jan 2008
Posts: 580
Location: Москва

PostPosted: Thu Mar 27, 2008 6:42 pm    Post subject: Reply with quote

Поищите поиском фразу "smbln =" в предоставленном коде.
_________________
С уважением,
Удав.
Back to top
View user's profile Send private message
vga
Мастер
Мастер


Age: 165
Joined: 04 Oct 2007
Posts: 1218
Location: Санкт-Петербург

PostPosted: Thu Mar 27, 2008 10:11 pm    Post subject: Reply with quote

Это часть кода из оборотки по материалам.
В итоговую таблицу для alv попадают только документы, по которым небыло сторнирующих документов.
Back to top
View user's profile Send private message Blog Visit poster's website
livur
Участник
Участник



Joined: 27 Mar 2008
Posts: 4
Location: moscow region

PostPosted: Mon Mar 31, 2008 1:40 pm    Post subject: вывод нестонированных ДМ Reply with quote

vga, подскажите, пожалуйста, что мне нужно дописать к этому коду, чтобы получилась работоспособная полноценная программа? только data для используемых переменных?
Back to top
View user's profile Send private message
vga
Мастер
Мастер


Age: 165
Joined: 04 Oct 2007
Posts: 1218
Location: Санкт-Петербург

PostPosted: Mon Mar 31, 2008 2:41 pm    Post subject: Reply with quote

Часть недостающих функций. До ума вам придется самому доводить, бизнес задачи у отчетов думаю разные.

Code:
*---------------------------------------------------------------------*
*       CLASS lcl_event_receiver DEFINITION
*---------------------------------------------------------------------*
*       ........                                                      *
*---------------------------------------------------------------------*
CLASS lcl_event_receiver DEFINITION.

  PUBLIC SECTION.
    CLASS-METHODS:

    handle_hotspot_click
      FOR EVENT hotspot_click OF cl_gui_alv_grid
        IMPORTING e_row_id e_column_id.

ENDCLASS.
*---------------------------------------------------------------------*
*       CLASS lcl_event_receiver IMPLEMENTATION
*---------------------------------------------------------------------*
*       ........                                                      *
*---------------------------------------------------------------------*
CLASS lcl_event_receiver IMPLEMENTATION.

* Grid Event

  METHOD handle_hotspot_click.
    CLEAR wa_res.
    READ TABLE itab_res INDEX e_row_id-index INTO wa_res.
    CHECK e_row_id-rowtype IS INITIAL.
    IF e_column_id-fieldname EQ 'KONTO'.

      DATA l_bukrs TYPE bukrs.
      SELECT SINGLE bukrs INTO l_bukrs
        FROM t001k WHERE bwkey = wa_res-bwkey.

      SET PARAMETER ID 'SAK' FIELD wa_res-konto.
      SET PARAMETER ID 'BUK' FIELD l_bukrs.
      CALL TRANSACTION 'FS03'.
    ELSEIF e_column_id-fieldname EQ 'MATNR'.
      SET PARAMETER ID 'MAT' FIELD wa_res-matnr.
      CALL TRANSACTION 'MM03'.
    ENDIF.
  ENDMETHOD.

ENDCLASS.

*&---------------------------------------------------------------------*
*&      Form  write_to_alv
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM write_to_alv TABLES itab.

ENDFORM.                    " write_to_alv
*&---------------------------------------------------------------------*
*&      Module  STATUS_9000  OUTPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE status_9000 OUTPUT.
  SET PF-STATUS '9000'.
  SET TITLEBAR '9000'.

ENDMODULE.                 " STATUS_9000  OUTPUT
*&---------------------------------------------------------------------*
*&      Module  PERFORM_ALV  OUTPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE perform_alv OUTPUT.

*initializing
  CREATE OBJECT container
    EXPORTING
      container_name = 'CONTAINER'.
  CREATE OBJECT alv_grid
    EXPORTING
     i_parent = container.

*  call method container->constructor
*    exporting
*      CONTAINER_NAME = 'CONTAINER'.

*perform
  CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
       EXPORTING
            i_program_name         = sy-cprog
            i_internal_tabname     = 'ITAB_RES'
            i_inclname             = 'XXX_TOP'
*            I_CLIENT_NEVER_DISPLAY = 'X'
       CHANGING
            ct_fieldcat            = gt_alv_fieldcat
       EXCEPTIONS
            inconsistent_interface = 1
            program_error          = 2
            OTHERS                 = 3.

  CALL FUNCTION 'LVC_TRANSFER_FROM_SLIS'
       EXPORTING
            it_fieldcat_alv = gt_alv_fieldcat
       IMPORTING
            et_fieldcat_lvc = gt_lvc_fcat
       TABLES
            it_data         = itab_res
       EXCEPTIONS
            it_data_missing = 1
            OTHERS          = 2.

  LOOP AT gt_lvc_fcat INTO gl_lvc_fcat.
    CASE gl_lvc_fcat-fieldname.
      WHEN 'BWKEY'.
        gl_lvc_fcat-no_out = 'X'.
      WHEN 'BWTAR'.
        gl_lvc_fcat-no_out = 'X'.
      WHEN 'MATNR'.
        gl_lvc_fcat-hotspot = 'X'.
        gl_lvc_fcat-fix_column = 'X'.
      WHEN 'KONTO'.
        gl_lvc_fcat-hotspot = 'X'.
        gl_lvc_fcat-fix_column = 'X'.
      WHEN 'DMBTR'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Open Amount'.
      WHEN 'MENGE'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Open Quantity'.
      WHEN 'DMBTR_1'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Receipt Amount'.
      WHEN 'MENGE_1'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Receipt Quantity'.
      WHEN 'DMBTR_2'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Issue Amount'.
      WHEN 'MENGE_2'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Issue Quantity'.
      WHEN 'DMBTR_3'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Turnover Amount'.
      WHEN 'MENGE_3'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Turnover Quantity'.
      WHEN 'DMBTR_4'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Closing Amount'.
      WHEN 'MENGE_4'.
        gl_lvc_fcat-do_sum = 'X'.
        gl_lvc_fcat-coltext = 'Closing Quantity'.
    ENDCASE.
    MODIFY gt_lvc_fcat FROM gl_lvc_fcat.
  ENDLOOP.

  DATA:
  wa_sort TYPE lvc_t_sort WITH HEADER LINE.
  wa_sort-fieldname = 'KONTO'.
  wa_sort-up = 'X'.
  wa_sort-spos = 1.
  wa_sort-subtot = 'X'.
  APPEND wa_sort TO gt_sort.

  DATA text(20).
  g_layo-grid_title = text-060.

  WRITE r_budat-low TO text.
  CONCATENATE g_layo-grid_title text
      INTO g_layo-grid_title SEPARATED BY space.
  CLEAR text.
  WRITE r_budat-high TO text.
  CONCATENATE g_layo-grid_title '-' text
      INTO g_layo-grid_title SEPARATED BY space.

  CALL METHOD alv_grid->set_table_for_first_display
    EXPORTING i_save  = 'A'
           is_layout  = g_layo

    CHANGING  it_fieldcatalog = gt_lvc_fcat
              it_outtab       = itab_res[]
              it_sort         = gt_sort.

  SET HANDLER lcl_event_receiver=>handle_hotspot_click FOR alv_grid.

ENDMODULE.                 " PERFORM_ALV  OUTPUT

*&---------------------------------------------------------------------*
*&      Module  USER_COMMAND_9000  INPUT
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
MODULE user_command_9000 INPUT.
  DATA: ok_code LIKE sy-ucomm.
  CASE ok_code.
    WHEN 'BACK' OR 'EXIT' OR 'CANCEL'.
      IF NOT container IS INITIAL.
        CALL METHOD container->free.
        FREE container.
*        CALL METHOD CL_GUI_CFW=>FLUSH.
      ENDIF.
*      if not alv_grid is initial.
*        call method alv_grid->free.
*      endif.

      LEAVE TO SCREEN 0.
  ENDCASE.
ENDMODULE.                 " USER_COMMAND_9000  INPUT

*&---------------------------------------------------------------------*
*&      Form  ORGANISATION
*&---------------------------------------------------------------------*
*       Einlesen der Tabellen T001, T001K, T030, T030R                 *
*----------------------------------------------------------------------*
FORM organisation.

 SELECT DISTINCT t001~mandt t001~bukrs t001~butxt t001~waers t001~ktopl
                                    t001k~bwkey t001k~bwmod t001k~xvkbw
                               INTO CORRESPONDING FIELDS OF TABLE organ
                                             FROM t001 INNER JOIN t001k
                                        ON t001~mandt = t001k~mandt AND
                                               t001~bukrs = t001k~bukrs
                                           WHERE t001k~bukrs IN s_bukrs
                                           AND   t001k~bwkey IN s_bwkey.
  SORT organ.
* Buchungsperioden (aktuelle und Vorperioden) werden aus MARV gelesen,
* in die Organisationsatabelle ORGAN gestellt und von dort in die
* Ausgabetabellen SALDO und HEADER _bertragen
  LOOP AT organ.
    ON CHANGE OF organ-bukrs.
      CALL FUNCTION 'MARV_SINGLE_READ'
           EXPORTING
                bukrs      = organ-bukrs
           IMPORTING
                wmarv      = marv
           EXCEPTIONS
                not_found  = 1
                wrong_call = 2
                OTHERS     = 3.
    ENDON.
    IF sy-subrc IS INITIAL.
      MOVE-CORRESPONDING marv TO organ.
      MODIFY organ.
    ELSE.
      DELETE organ.
    ENDIF.
  ENDLOOP.

* If already here not more entries in ORGAN (wrong CC or combination)
* leave. The rest of this report is not designed to recognize this
* and totally fails with SELECT ... FOR ALL ENTRIES IN ORGAN.
  CHECK NOT organ[] IS INITIAL.                             "357162

* 'inner join' ist nur f_r transparente Tabellen, jedoch nicht f_r
* Pooltabellen m_glich.
  SELECT * FROM t030r
           FOR ALL ENTRIES IN organ WHERE ktopl EQ organ-ktopl
                                    AND   ktosl EQ 'BSX'.
    IF t030r-xbkla IS INITIAL.
      CLEAR s_bklas. REFRESH s_bklas.
    ENDIF.
    SELECT * FROM t030 WHERE ktopl EQ t030r-ktopl
                       AND   ktosl EQ 'BSX'
                       AND   bklas IN s_bklas
                       AND   konts IN s_skont.
*     Stimmt die automatische Kontenfindung f_r die Bestandsbuchung
*     mit den zulфssigen Customizing-Einstellungen (vergleiche mit
*     Include DFKB1INT) _berein (keine Kontomodifikation und keine
*     voneinander abweichende Soll- und Habenkonten erlaubt)?
      IF NOT t030-komok IS INITIAL OR                       "note209823
        t030-konts NE t030-konth.                           "note209823
        MOVE t030-ktopl TO message_text.
        WRITE 'BSX' TO message_text+10.
        WRITE t030-konts TO message_text+20.
        CONDENSE message_text.
        MESSAGE s147(m8) WITH message_text.
*       Kontenfindung f_r den Eintrag & nicht m_glich
        EXIT.
      ENDIF.
      ON CHANGE OF t030-ktopl OR t030-konts.
        SELECT SINGLE * FROM skat WHERE spras = sy-langu
                                  AND   ktopl = t030-ktopl
                                  AND   saknr = t030-konts.
      ENDON.
      MOVE-CORRESPONDING t030 TO it030.
      MOVE-CORRESPONDING skat TO it030.
      MOVE-CORRESPONDING t030r TO it030.
      APPEND it030.
    ENDSELECT.
*   Bewertungsmodifikation eingeschaltet?
    IF t030r-xbwmo IS INITIAL.                        "note 358829
      LOOP AT organ WHERE ktopl EQ t030r-ktopl        "note 358829
                    AND   bwmod NE space.             "note 358829
        CLEAR organ-bwmod.                            "note 358829
        MODIFY organ.                                 "note 358829
      ENDLOOP.                                        "note 358829
    ENDIF.                                            "note 358829
    LOOP AT organ WHERE ktopl EQ t030r-ktopl.         "note 358829
      organ-xbkla = t030r-xbkla.                      "note 358829
      MODIFY organ.                                   "note 358829
    ENDLOOP.                                          "note 358829
  ENDSELECT.

  SORT it030 BY bklas.
  IF NOT s_skont IS INITIAL.
    DESCRIBE TABLE it030 LINES index_z.
    IF index_z IS INITIAL.
      MESSAGE s055 WITH s_skont-low s_bukrs-low.
*     Das Sachkonto & ist im Buchungskreis & nicht vorhanden
      EXIT.
    ENDIF.
    LOOP AT it030.
      ON CHANGE OF it030-bklas.
        CHECK it030-bklas IN s_bklas.
        MOVE 'I'  TO ibklas-sign.
        MOVE 'EQ' TO ibklas-option.
        MOVE it030-bklas TO ibklas-low.
        APPEND ibklas.
      ENDON.
    ENDLOOP.
    DESCRIBE TABLE ibklas LINES index_z.
    IF index_z IS INITIAL.
      MESSAGE s843.
*     Zu den vorgegebenen Daten ist kein Bestand vorhanden
      EXIT.
    ENDIF.
  ENDIF.
  SORT it030.

ENDFORM.                               " ORGANISATION

*&---------------------------------------------------------------------*
*&      Form  SELEKTION_BEARBEITEN
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
FORM selektion_bearbeiten.

  SORT xmbew BY bwkey bklas.
  LOOP AT xmbew.
* Wertartikel: Verkaufswerte anzeigen
    READ TABLE organ WITH KEY mandt = sy-mandt
                              bwkey = xmbew-bwkey BINARY SEARCH.
    IF NOT organ-xvkbw IS INITIAL.
* Verkaufspreisbewertung ist in diesem Bewertungskreis aktiv geschaltet.
* Es muп gepr_ft werden, ob es sich um einen Wertartikel handelt.
      MOVE c_ja TO xmbew-xvkbw.
      READ TABLE xmarav                                     "353378
                 WITH KEY matnr = xmbew-matnr BINARY SEARCH."353378
* Die Materialart des Artikels wird gelesen:
      SELECT SINGLE * FROM t134m WHERE bwkey = xmbew-bwkey
                                 AND   mtart = xmarav-mtart.
      IF sy-subrc IS INITIAL.
        IF t134m-wertu = c_ja AND t134m-mengu = c_nein.
*       Es handelt sich um einen Wertartikel
          MOVE c_ja TO xmbew-ke_xwart.
        ELSE.
*       Es handelt sich nicht um einen Wertartikel
          MOVE c_nein TO xmbew-ke_xwart.
        ENDIF.
      ELSE.
*       Materialart nicht gefunden.
*       error fixed ( reported by extended syntax check )   "n490469
        MESSAGE s001                                        "n490469
           WITH 'T134M' xmbew-bwkey xmarav-mtart space.     "n490469
      ENDIF.
    ELSE.
      MOVE c_nein TO xmbew-ke_xwart.
      MOVE c_nein TO xmbew-xvkbw.
    ENDIF.
*    IF xmbew-ke_xwart IS INITIAL.    "Nullbestand
*      IF xmbew-lbkum = null.
*        DELETE xmbew.
*        CHECK xmbew-lbkum NE null.
*      ENDIF.
*    ELSEIF NOT xmbew-ke_xwart IS INITIAL.
*      IF xmbew-vksal = null.
*        DELETE xmbew.
*        CHECK xmbew-vksal NE null.
*      ENDIF.
*    ENDIF.
    ON CHANGE OF xmbew-bklas OR xmbew-bwkey.
      rc = 0.
      PERFORM sachkonto.
    ENDON.
    IF rc NE 0.
      DELETE xmbew.
      CHECK rc = 0.
    ENDIF.
    MOVE xkonto TO xmbew-xkonto.
    MOVE organ-bukrs TO xmbew-bukrs.
    MOVE organ-butxt TO xmbew-butxt.
    MODIFY xmbew.
  ENDLOOP.

ENDFORM.                               " SELEKTION_BEARBEITEN

*---------------------------------------------------------------------*
*                FORM SACHKONTO                                       *
*---------------------------------------------------------------------*
*                Ermitteln Sachkonto und Sachkontentext               *
*---------------------------------------------------------------------*
FORM sachkonto.

  CLEAR: organ, it030.
  READ TABLE organ WITH KEY bwkey = xmbew-bwkey.
  x030_key-mandt = sy-mandt.
  x030_key-ktopl = organ-ktopl.
  x030_key-ktosl = 'BSX'.
  x030_key-bwmod = organ-bwmod.
  x030_key-bklas = xmbew-bklas.                         "note 358829
  IF organ-xbkla IS INITIAL.                            "note 358829
    CLEAR x030_key-bklas.                               "note 358829
  ENDIF.                                                "note 358829
  READ TABLE it030 WITH KEY x030_key.
  xkonto = it030-konts.
  IF NOT sy-subrc IS INITIAL.
    rc = 4.
  ENDIF.

ENDFORM.

*---------------------------------------------------------------------*
*       FORM print_report                                             *
*---------------------------------------------------------------------*
*       ........                                                      *
*---------------------------------------------------------------------*
FORM print_report.

  DATA: wa_alv_fieldcat  TYPE slis_fieldcat_alv.


*perform
  CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
       EXPORTING
            i_program_name         = sy-cprog
            i_internal_tabname     = 'ITAB_RES'
            i_inclname             = 'ZERUFR_MB_TURNOVER_TOP'
*            I_CLIENT_NEVER_DISPLAY = 'X'
       CHANGING
            ct_fieldcat            = gt_alv_fieldcat
       EXCEPTIONS
            inconsistent_interface = 1
            program_error          = 2
            OTHERS                 = 3.

  DEFINE rename_field.
    wa_alv_fieldcat-do_sum = 'X'.
    wa_alv_fieldcat-seltext_l = &1.
*    wa_alv_fieldcat-seltext_m = &1.
*    wa_alv_fieldcat-seltext_s = &1.
  END-OF-DEFINITION.


  LOOP AT gt_alv_fieldcat INTO wa_alv_fieldcat.
    CASE wa_alv_fieldcat-fieldname.
      WHEN 'BWKEY'.
        wa_alv_fieldcat-no_out = 'X'.
      WHEN 'BWTAR'.
        wa_alv_fieldcat-no_out = 'X'.
      WHEN 'MATNR'.
        wa_alv_fieldcat-hotspot = 'X'.
        wa_alv_fieldcat-fix_column = 'X'.
      WHEN 'KONTO'.
        wa_alv_fieldcat-hotspot = 'X'.
        wa_alv_fieldcat-fix_column = 'X'.
      WHEN 'DMBTR'.
        rename_field 'Open Amount'.
      WHEN 'MENGE'.
        rename_field 'Open Quantity'.
      WHEN 'DMBTR_1'.
        rename_field 'Receipt Amount'.
      WHEN 'MENGE_1'.
        rename_field 'Receipt Quantity'.
      WHEN 'DMBTR_2'.
        rename_field 'Issue Amount'.
      WHEN 'MENGE_2'.
        rename_field 'Issue Quantity'.
      WHEN 'DMBTR_3'.
        rename_field 'Turnover Amount'.
      WHEN 'MENGE_3'.
        rename_field 'Turnover Quantity'.
      WHEN 'DMBTR_4'.
        rename_field 'Closing Amount'.
      WHEN 'MENGE_4'.
        rename_field 'Closing Quantity'.
    ENDCASE.
    MODIFY gt_alv_fieldcat FROM wa_alv_fieldcat.
  ENDLOOP.

  DATA:
  lt_sort TYPE slis_t_sortinfo_alv,
  wa_sort TYPE slis_sortinfo_alv.
  wa_sort-fieldname = 'KONTO'.
  wa_sort-up = 'X'.
  wa_sort-spos = 1.
  wa_sort-subtot = 'X'.
  APPEND wa_sort TO lt_sort.

  DATA text(20).
  g_layo-grid_title = text-060.

  WRITE r_budat-low TO text.
  CONCATENATE g_layo-grid_title text
      INTO g_layo-grid_title SEPARATED BY space.
  CLEAR text.
  WRITE r_budat-high TO text.
  CONCATENATE g_layo-grid_title '-' text
      INTO g_layo-grid_title SEPARATED BY space.

  CALL FUNCTION  'REUSE_ALV_GRID_DISPLAY' "kea always alv grid
    EXPORTING
*      i_interface_check          = l_f_check
      i_callback_program         = sy-cprog "repid
*      i_callback_user_command    = 'USER_COMMAND'
     i_grid_title               = g_layo-grid_title
*      is_layout                  = g_layo
      it_fieldcat                = gt_alv_fieldcat[]
      it_sort                    = lt_sort[]
      i_default                  = 'X'
      i_save                     = 'A'
*      is_variant                 = variante_flat
*      it_events                  = events[]
*      is_print                   = alv_print
    TABLES
      t_outtab                   = itab_res[]
    EXCEPTIONS
      OTHERS                     = 2.

ENDFORM.
Back to top
View user's profile Send private message Blog Visit poster's website
Display posts from previous:   
Post new topic   Reply to topic    Russian ABAP Developer's Club Forum Index -> ABAP All times are GMT + 4 Hours
Page 1 of 1

 
Jump to:  
You cannot post new topics in this forum
You cannot reply to topics in this forum
You cannot edit your posts in this forum
You cannot delete your posts in this forum
You cannot vote in polls in this forum
You cannot attach files in this forum
You can download files in this forum


All product names are trademarks of their respective companies. SAPNET.RU websites are in no way affiliated with SAP AG.
SAP, SAP R/3, R/3 software, mySAP, ABAP, BAPI, xApps, SAP NetWeaver and any other are registered trademarks of SAP AG.
Every effort is made to ensure content integrity. Use information on this site at your own risk.