ABAP:报告具有包含颜色信息的“ farbe”列

时间:2018-12-07 11:47:21

标签: sap abap

我正在使用此abap函数以json格式导出报告。

FUNCTION /MLK/GET_REPORT_DATA .
*"----------------------------------------------------------------------
*"*"Lokale Schnittstelle:
*"  IMPORTING
*"     VALUE(IV_REPORT_NAME) TYPE  PROGRAMM
*"     VALUE(IV_DYNAMIC_PARAMETER_LIST) TYPE  WDY_KEY_VALUE_LIST
*"       OPTIONAL
*"     VALUE(IV_SELECTION_SET_VARIANT) TYPE  RALDB_VARI OPTIONAL
*"  EXPORTING
*"     VALUE(EV_RESULT_JSON) TYPE  STRING
*"----------------------------------------------------------------------

cl_salv_bs_runtime_info=>set(
 EXPORTING
   display  = abap_false
   metadata = abap_false
   data     = abap_true
).


data selection_table TYPE TABLE OF RSPARAMS.

PERFORM GET_REPORT_READ_PARAMETER
    USING IV_DYNAMIC_PARAMETER_LIST
   CHANGING selection_table.


if IV_SELECTION_SET_VARIANT is INITIAL.
  SUBMIT (IV_REPORT_NAME)
     WITH SELECTION-TABLE selection_table
    AND RETURN.
ELSE.
  SUBMIT (IV_REPORT_NAME)
     WITH SELECTION-TABLE selection_table
     USING SELECTION-SET IV_SELECTION_SET_VARIANT
    AND RETURN.
endif.


FIELD-SYMBOLS <lt_data>             TYPE ANY TABLE.
FIELD-SYMBOLS <lt_data_line>        TYPE ANY TABLE.

DATA          lr_data               TYPE REF TO data.
DATA          lr_data_line          TYPE REF TO data.
DATA          lr_data_descr          TYPE REF TO cl_abap_datadescr.
DATA          lr_data_line_descr    TYPE REF TO cl_abap_datadescr.

cl_salv_bs_runtime_info=>get_data_ref(
     IMPORTING r_data_descr      = lr_data_descr
                          r_data_line_descr = lr_data_line_descr ).

IF lr_data_descr IS NOT BOUND.
  ev_result_json = '[]'.
  EXIT.
ENDIF.


CREATE DATA lr_data         TYPE HANDLE lr_data_descr.
CREATE DATA lr_data_line    TYPE HANDLE lr_data_line_descr.

ASSIGN lr_data->*           TO <lt_data>.
ASSIGN lr_data_line->*      TO <lt_data_line>.

DATA lx_runtime_info TYPE REF TO cx_salv_bs_sc_runtime_info.

TRY.

* hierarchical report

  cl_salv_bs_runtime_info=>get_data(
    IMPORTING
      t_data      = <lt_data>
      t_data_line = <lt_data_line>
         ).
  ev_result_json = /ui2/cl_json=>serialize( data = <lt_data_line> pretty_name = /ui2/cl_json=>pretty_mode-low_case ).

CATCH cx_salv_bs_sc_runtime_info INTO lx_runtime_info.
* normal (flat) report
  cl_salv_bs_runtime_info=>get_data(
    IMPORTING
      t_data      = <lt_data>
         ).
  ev_result_json = /ui2/cl_json=>serialize( data = <lt_data> pretty_name = /ui2/cl_json=>pretty_mode-low_case ).

ENDTRY.
cl_salv_bs_runtime_info=>clear_all( ).

ENDFUNCTION.


FORM GET_REPORT_READ_PARAMETER
  USING parameter_list TYPE  WDY_KEY_VALUE_LIST
  CHANGING sel_table TYPE RSPARAMS_TT.


data key_value TYPE wdy_key_value.
data key_value2 TYPE wdy_key_value.
data selection_row TYPE RSPARAMS.

LOOP AT parameter_list INTO key_value.
    selection_row-selname = key_value-key.
    selection_row-low = key_value-value.
    selection_row-sign = 'I'.
    selection_row-option = 'EQ'.
   APPEND selection_row to sel_table.
ENDLOOP.

ENDFORM.

表格JSON结果包含一个名为“ farbe”的列。这是德语中“颜色”的意思。

此处是此列的内容。 AFAIK表格结果的每一行都有一个字典。

[
  {
    "color": {
      "int": 0, 
      "inv": 0, 
      "col": 0
    }, 
    "fieldname": "LABST", 
    "nokeycol": ""
  }, 
  {
    "color": {
      "int": 0, 
      "inv": 0, 
      "col": 0
    }, 
    "fieldname": "MEINS", 
    "nokeycol": ""
  }, 
 ....
 ]

我想删除此列“ farbe”。

但是我希望这适用于所有sap报告。

我不确定在非德语系统上此列是否被称为其他列。也许在英语系统中被称为“颜色”?

如何查找包含不需要的颜色信息的列名(在本例中为“ farbe”)?

(如何过滤JSON并不是问题的一部分)

1 个答案:

答案 0 :(得分:2)

您不知道ALV中使用的名称,这些名称可能因报告而异。

如果ALV网格中有一个颜色列,则该列将为 LVC_T_SCOL类型。因此,您可以使用CL_ABAP_TYPEDESCR之类的RTTI类来检测它。

当然,如果满足以下条件,一种适用于所有报表的通用方法将无法获得ALV中的颜色列:

  • 某些ALV根本不输出任何颜色(因此可能没有颜色列)
  • 仅ALV的列是彩色的,不需要颜色列,而是使用字段目录设置颜色。
  • 许多报告甚至都没有生成“网格”类型的ALV(您的情况就是如此)。有些报告使用ALV列表(与上面的注释相同,但颜色列的类型不同)。