gpt4 book ai didi

abap - 创建动态ABAP内表

转载 作者:行者123 更新时间:2023-12-04 11:20:48 27 4
gpt4 key购买 nike

在选择屏幕上,用户需要插入一个表名,我需要从该表中获取前 3 个字段并将它们显示在 ALV 中以供输出。我从阅读教程中了解到,我需要调用方法 cl_alv_table_create=>create_dynamic_table ,但我不知道如何创建 fieldcatalog。

DATA: t_newtable   TYPE REF TO data,
t_fldcat TYPE lvc_t_fcat,

CALL METHOD cl_alv_table_create=>create_dynamic_table
EXPORTING
it_fieldcatalog = t_fldcat
IMPORTING
ep_table = t_newtable.

最佳答案

我假设用户输入的表名是数据字典表(如 SFLIGHT)。如果是,那么您可以按如下方式生成字段目录。

data : it_tabdescr type abap_compdescr_tab,
wa_tabdescr type abap_compdescr.
data : ref_table_descr type ref to cl_abap_structdescr.

ref_table_descr ?= cl_abap_typedescr=>describe_by_name( p_table ).
it_tabdescr[] = ref_table_descr->components[].
loop at it_tabdescr into wa_tabdescr.
clear wa_fieldcat.
wa_fieldcat-fieldname = wa_tabdescr-name .
wa_fieldcat-datatype = wa_tabdescr-type_kind.
wa_fieldcat-inttype = wa_tabdescr-type_kind.
wa_fieldcat-intlen = wa_tabdescr-length.
wa_fieldcat-decimals = wa_tabdescr-decimals.
append wa_fieldcat to it_fieldcat.
endloop.

Here, "p_table" is the selection screen parameter containing the table name.

关于abap - 创建动态ABAP内表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39956543/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com