0
点赞
收藏
分享

微信扫一扫

ALV demo 02:cl_salv_table 添加排序和汇总

JakietYu 2022-12-29 阅读 143


接着上篇文章,这次添加排序。

ALV demo 02:cl_salv_table 添加排序和汇总_CL

DATA: GT_DATA TYPE TABLE OF SFLIGHT.

DATA: GR_TABLE TYPE REF TO CL_SALV_TABLE.
"tool bar
DATA: GR_FUNCTIONS TYPE REF TO CL_SALV_FUNCTIONS
      .
"Columns – CL_SALV_COLUMNS_TABLE and CL_SALV_COLUMN_TABLE
DATA: GR_COLUMNS TYPE REF TO CL_SALV_COLUMNS_TABLE.
DATA: GR_COLUMN  TYPE REF TO CL_SALV_COLUMN_TABLE.
DATA: COLOR TYPE LVC_S_COLO.
*Sorts – CL_SALV_SORTS
DATA: GR_SORTS TYPE REF TO CL_SALV_SORTS.
 
START-OF-SELECTION.

  SELECT * INTO TABLE GT_DATA FROM SFLIGHT.

  CL_SALV_TABLE=>FACTORY( IMPORTING R_SALV_TABLE = GR_TABLE CHANGING T_TABLE = GT_DATA ).

*tool bar
  GR_FUNCTIONS = GR_TABLE->GET_FUNCTIONS( ).
  GR_FUNCTIONS->SET_ALL( ABAP_TRUE ).


  GR_COLUMNS = GR_TABLE->GET_COLUMNS( ).
  GR_COLUMN ?= GR_COLUMNS->GET_COLUMN( 'MANDT' ).

  CALL METHOD GR_COLUMN->SET_VISIBLE
    EXPORTING
      VALUE = IF_SALV_C_BOOL_SAP=>FALSE.


*Sorts – CL_SALV_SORTS
  GR_SORTS = GR_TABLE->GET_SORTS( ).
  GR_SORTS->ADD_SORT( COLUMNNAME = 'CARRID' ).

  GR_TABLE->DISPLAY( ).


再加个汇总吧

ALV demo 02:cl_salv_table 添加排序和汇总_ABAP_02

根据币种分别汇总了。

DATA: GT_DATA TYPE TABLE OF SFLIGHT.

DATA: GR_TABLE TYPE REF TO CL_SALV_TABLE.
"tool bar
DATA: GR_FUNCTIONS TYPE REF TO CL_SALV_FUNCTIONS
      .
"Columns – CL_SALV_COLUMNS_TABLE and CL_SALV_COLUMN_TABLE
DATA: GR_COLUMNS TYPE REF TO CL_SALV_COLUMNS_TABLE.
DATA: GR_COLUMN  TYPE REF TO CL_SALV_COLUMN_TABLE.
DATA: COLOR TYPE LVC_S_COLO.
*Sorts – CL_SALV_SORTS
DATA: GR_SORTS TYPE REF TO CL_SALV_SORTS.

*Aggregations – CL_SALV_AGGREGATIONS
DATA: GR_AGG TYPE REF TO CL_SALV_AGGREGATIONS.


START-OF-SELECTION.

  SELECT * INTO TABLE GT_DATA FROM SFLIGHT.

  CL_SALV_TABLE=>FACTORY( IMPORTING R_SALV_TABLE = GR_TABLE CHANGING T_TABLE = GT_DATA ).

*tool bar
  GR_FUNCTIONS = GR_TABLE->GET_FUNCTIONS( ).
  GR_FUNCTIONS->SET_ALL( ABAP_TRUE ).

  GR_COLUMNS = GR_TABLE->GET_COLUMNS( ).
  GR_COLUMN ?= GR_COLUMNS->GET_COLUMN( 'MANDT' ).

  CALL METHOD GR_COLUMN->SET_VISIBLE
    EXPORTING
      VALUE = IF_SALV_C_BOOL_SAP=>FALSE.

*Sorts – CL_SALV_SORTS
  GR_SORTS = GR_TABLE->GET_SORTS( ).
  GR_SORTS->ADD_SORT( COLUMNNAME = 'CARRID' ).

*  Aggregations – CL_SALV_AGGREGATIONS

  GR_AGG = GR_TABLE->GET_AGGREGATIONS( ).
  GR_AGG->ADD_AGGREGATION( 'PRICE' ).

  GR_TABLE->DISPLAY( ).


再换个效果:

ALV demo 02:cl_salv_table 添加排序和汇总_ABAP_03

根据币种排序,汇总。

参考代码:

REPORT ZLM_ALV001.


DATA: GT_DATA TYPE TABLE OF SFLIGHT.

DATA: GR_TABLE TYPE REF TO CL_SALV_TABLE.
"tool bar
DATA: GR_FUNCTIONS TYPE REF TO CL_SALV_FUNCTIONS
      .
"Columns – CL_SALV_COLUMNS_TABLE and CL_SALV_COLUMN_TABLE
DATA: GR_COLUMNS TYPE REF TO CL_SALV_COLUMNS_TABLE.
DATA: GR_COLUMN  TYPE REF TO CL_SALV_COLUMN_TABLE.
DATA: COLOR TYPE LVC_S_COLO.
*Sorts – CL_SALV_SORTS
DATA: GR_SORTS TYPE REF TO CL_SALV_SORTS.

*Aggregations – CL_SALV_AGGREGATIONS
DATA: GR_AGG TYPE REF TO CL_SALV_AGGREGATIONS.


START-OF-SELECTION.

  SELECT * INTO TABLE GT_DATA FROM SFLIGHT.

  CL_SALV_TABLE=>FACTORY( IMPORTING R_SALV_TABLE = GR_TABLE CHANGING T_TABLE = GT_DATA ).

*tool bar
  GR_FUNCTIONS = GR_TABLE->GET_FUNCTIONS( ).
  GR_FUNCTIONS->SET_ALL( ABAP_TRUE ).


  GR_COLUMNS = GR_TABLE->GET_COLUMNS( ).
  GR_COLUMN ?= GR_COLUMNS->GET_COLUMN( 'MANDT' ).

  CALL METHOD GR_COLUMN->SET_VISIBLE
    EXPORTING
      VALUE = IF_SALV_C_BOOL_SAP=>FALSE.

*Sorts – CL_SALV_SORTS
  GR_SORTS = GR_TABLE->GET_SORTS( ).
*  "Aggregations – CL_SALV_AGGREGATIONS
  GR_SORTS->ADD_SORT( COLUMNNAME = 'CURRENCY' SUBTOTAL = ABAP_TRUE ).
  GR_AGG = GR_TABLE->GET_AGGREGATIONS( ).
  GR_AGG->ADD_AGGREGATION( 'PRICE' ).

  GR_TABLE->DISPLAY( ).

举报

相关推荐

0 条评论