ABAP 创建动态内表示例

根据年月输出不同列,比如201812->31 列,201802->28列

*&---------------------------------------------------------------------*
*& Report ZDEMO_CRT_DYN_ITAB
*&---------------------------------------------------------------------*
*&
*&---------------------------------------------------------------------*
REPORT ZDEMO_CRT_DYN_ITAB.

PARAMETERS:
  P_YEAR  TYPE /BCV/FND_YEAR OBLIGATORY,  "年度
  P_MONTH TYPE MONTH OBLIGATORY.          "月份

INITIALIZATION.
  P_YEAR = SY-DATUM+0(4).
  P_MONTH = SY-DATUM+4(2).

AT SELECTION-SCREEN.

START-OF-SELECTION.
  "Create dynamic internal table
  PERFORM FRM_CT_DYN_ITAB.

*&---------------------------------------------------------------------*
*& Form FRM_CT_DYN_ITAB
*&---------------------------------------------------------------------*
*& text
*&---------------------------------------------------------------------*
*& -->  p1        text
*& <--  p2        text
*&---------------------------------------------------------------------*
FORM FRM_CT_DYN_ITAB .

  DATA: LV_BEG_DATE TYPE SY-DATUM,
        LV_END_DATE TYPE SY-DATUM,
        LV_DAYS     TYPE I.

  DATA:LT_FDCAT TYPE LVC_T_FCAT.

  "Set dynamic itab
  LV_BEG_DATE = |{ P_YEAR }{ P_MONTH ALPHA = IN }01|.
  "Get final day of curren month
  CALL FUNCTION 'BKK_GET_MONTH_LASTDAY'
    EXPORTING
      I_DATE = LV_BEG_DATE
    IMPORTING
      E_DATE = LV_END_DATE.

  LV_DAYS = LV_END_DATE+6(2).

  DO LV_DAYS TIMES.
    LT_FDCAT = VALUE #( BASE LT_FDCAT
                        ( FIELDNAME = |DAY{ SY-INDEX }|
                          INTTYPE   = |P|
                          INTLEN    = |13|
                          DECIMALS  = |2|
                          SCRTEXT_L = |DAY{ SY-INDEX }|
                          SCRTEXT_M = |DAY{ SY-INDEX }|
                          SCRTEXT_S = |DAY{ SY-INDEX }| ) ).
  ENDDO.

  CL_ALV_TABLE_CREATE=>CREATE_DYNAMIC_TABLE(
    EXPORTING
      IT_FIELDCATALOG           = LT_FDCAT    " Field Catalog
    IMPORTING
      EP_TABLE                  = DATA(LS_EP_TABLE)
    EXCEPTIONS
      GENERATE_SUBPOOL_DIR_FULL = 1
      OTHERS                    = 2
  ).

  FIELD-SYMBOLS:<FT_TAB> TYPE STANDARD TABLE.
  ASSIGN LS_EP_TABLE->* TO <FT_TAB>.

  "Set value
  APPEND INITIAL LINE TO <FT_TAB> ASSIGNING FIELD-SYMBOL(<FS_TAB>).
  DO LV_DAYS TIMES.
    ASSIGN COMPONENT SY-INDEX OF STRUCTURE <FS_TAB> TO FIELD-SYMBOL(<FD>).
    IF <FD> IS ASSIGNED.
      <FD> = SY-INDEX.
      UNASSIGN <FD>.
    ENDIF.
  ENDDO.

  "ALV
  CL_SALV_TABLE=>FACTORY(
        IMPORTING
          R_SALV_TABLE = DATA(LCL_ALV)
        CHANGING
          T_TABLE      = <FT_TAB> ).

  LCL_ALV->DISPLAY( ).

ENDFORM.

 

生成的动态内表<FT_TAB>

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

王小磊

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值