ABAP动态内表操作
动态内表的列是可以跟随数据的变化而变化,可以使报表显示更简洁漂亮。
REPORT zdyn_test.
DATA: dyn_table TYPE REF TO data,
dyn_line TYPE REF TO data,
FIELD-SYMBOLS: <dyn_table> TYPE STANDARD TABLE.
FIELD-SYMBOLS: <dyn_wa> TYPE ANY.
FIELD-SYMBOLS: <dyn_field> TYPE ANY.
DATA: layout TYPE LVC_S_LAYO,
structures TYPE lvc_t_fcat,
structure TYPE lvc_s_fcat.
START-OF-SELECTION.
PERFORM create_structure. "定义内表的结构"
PERFORM create_dynamic_table. "按照定义的内表结构,产生一个内表"
PERFORM write_data_to_dyntable. "向动态内表中写数"
PERFORM output_dyntable_data. "从动态内表中取数,并写到屏幕"
Step1:创建动态内表
动态内表的结构的定义.
动态内表表结构的定义必须使用表结构与 lvc_t_fcat 一样的内表。一般情况下,我们都内表的所有列定义成字符型.
*&-----------------------------------------------------------*
*& Form create_structure
*&-----------------------------------------------------------*
FORM create_structure .
structure-fieldname = 'COL1'. " 第一列列名 "
structure-col_pos = 1.
structure-inttype = 'C'. " 数据类型 "
structure-intlen = 6. " 长度 "
APPEND structure TO structures.
structure-fieldname = 'COL2'. " 第二列列名 "
structure-col_pos = 2.
structure-inttype = 'C'. " 数据类型 "
structure-intlen = 6. " 长度 "
APPEND wa_structure TO structures.
structure-fieldname = 'COL3'. " 第三列名 "
structure-col_pos = 3.
structure-inttype = 'C'. " 数据类型 "
structure-intlen = 6. " 长度 "
APPEND structure TO structures.
ENDFORM. " create_structure "
根据表结构生成内表.
系统提供了一个标准的 method 来产生动态表,使用方法如下:
*&-----------------------------------------------------------*
*& Form create_dynamic_table
*&-----------------------------------------------------------*
FORM create_dynamic_table .
CALL METHOD cl_alv_table_create=>create_dynamic_table
EXPORTING
it_fieldcatalog = structures
IMPORTING
ep_table = dyn_table.
"用表类型指针<dyn_table>指向数据对象的内容. "
ASSIGN dyn_table->* TO <dyn_table>.
ENDFORM. " create_dynamic_table "
Step2:动态内表的赋值
获取指定的字段并给指定的字段赋值
*&-----------------------------------------------------------*
*& Form write_data_to_dyntable
*&-----------------------------------------------------------*
FORM write_data_to_dyntable .
DATA:i TYPE n.
DATA:j TYPE n.
" 建立一个与动态内表结构相同的数据对象,且数据对象为是一个结构 "
CREATE DATA dyn_line LIKE LINE OF <dyn_table>.
ASSIGN dyn_line->* TO <dyn_wa>. " 用<dyn_wa>指针指向该结构 "
DO 3 TIMES.
i = i + 1.
CLEAR j.
LOOP AT structures INTO structure.
j = j + 1.
" 用指针<dyn_field>指向工作区<dyn_wa>中的一个字段,字段名为structure-fieldname. "
ASSIGN COMPONENT structure-fieldname OF STRUCTURE <dyn_wa> TO <dyn_field>.
CONCATENATE i j INTO <dyn_field>. " 给指针指向的字段赋值 "
ENDLOOP.
APPEND <dyn_wa> TO <dyn_table>.
CLEAR <dyn_wa>.
ENDDO.
ENDFORM. " write_data_to_dyntable "
*&-----------------------------------------------------------*
Step3:读取动态内表的值
获取指定的字段并读取指定的字段值
*&-----------------------------------------------------------*
*& Form output_dyntable_data
*&-----------------------------------------------------------*
FORM output_dyntable_data .
LOOP AT structures INTO structure.
WRITE: structure-fieldname(5).
ENDLOOP.
LOOP AT <dyn_table> INTO <dyn_wa>.
WRITE: / .
CLEAR structure.
LOOP AT structures INTO structure.
" 用指针<dyn_field>指向工作区<dyn_wa>中的一个字段,字段名为structure-fieldname. "
ASSIGN COMPONENT structure-fieldname OF STRUCTURE <dyn_wa> TO <dyn_field>.
WRITE: <dyn_field>.
ENDLOOP.
ENDLOOP.
ENDFORM. " output_dyntable_data "