Application Development and Automation Discussions
Join the discussions or start your own on all things application development, including tools and APIs, programming models, and keeping your skills sharp.
cancel
Showing results for 
Search instead for 
Did you mean: 
Read only

dynamic structure

Former Member
0 Likes
1,135

hi,

i want ot create a structure like:

types : begin of ty_struct,

col1 ,

col2,

......

......

......

end of ty_struct.

the no.of columns depend on a integre value....if the integer

value is 10 then structure will have 10 columns ,if 15 then 15 and so on.

how to create this structure.

1 ACCEPTED SOLUTION
Read only

Former Member
0 Likes
1,113

Hi,

I think I have the solution for your requirement, just run the code below it will serve your purpose.

type-pools: slis.

field-symbols: <dyn_table> type standard table,

<dyn_wa>.

data: alv_fldcat type slis_t_fieldcat_alv,

it_fldcat type lvc_t_fcat.

selection-screen begin of block b1 with frame title text-001.

parameters: p_flds(5) type c.

selection-screen end of block b1.

start-of-selection.

*build the dynamic internal table

perform build_dyn_itab.

*write 5 records to the alv grid

do 5 times.

perform build_report.

enddo.

*call the alv grid.

perform call_alv.

************************************************************************

*Build_dyn_itab

************************************************************************

form build_dyn_itab.

data: new_table type ref to data,

new_line type ref to data,

wa_it_fldcat type lvc_s_fcat.

*Create fields .

clear wa_it_fldcat.

wa_it_fldcat-fieldname = 'name1'.

wa_it_fldcat-datatype = 'mara-matnr'.

wa_it_fldcat-intlen = 5.

append wa_it_fldcat to it_fldcat .

*

*clear wa_it_fldcat.

wa_it_fldcat-fieldname = sy-index.

wa_it_fldcat-datatype = 'CHAR'.

wa_it_fldcat-intlen = 5.

append wa_it_fldcat to it_fldcat .

*

do p_flds times.

clear wa_it_fldcat.

wa_it_fldcat-fieldname = sy-index.

wa_it_fldcat-datatype = 'CHAR'.

wa_it_fldcat-intlen = 6.

append wa_it_fldcat to it_fldcat .

enddo.

*Create dynamic internal table and assign to FS

call method cl_alv_table_create=>create_dynamic_table

exporting

it_fieldcatalog = it_fldcat

importing

ep_table = new_table.

assign new_table->* to <dyn_table>.

*Create dynamic work area and assign to FS

create data new_line like line of <dyn_table>.

assign new_line->* to <dyn_wa>.

endform.

*********************************************************************

*Form build_report

*********************************************************************

form build_report.

data: fieldname(20) type c.

data: fieldvalue(5) type c.

data: index(3) type c.

field-symbols: <fs1>.

do p_flds times.

index = sy-index.

*Set up fieldvalue

concatenate 'FLD' index into

fieldvalue.

condense fieldvalue no-gaps.

assign component index of structure <dyn_wa> to <fs1>.

<fs1> = fieldvalue.

enddo.

*Append to the dynamic internal table

append <dyn_wa> to <dyn_table>.

endform.

************************************************************************

*CALL_ALV

************************************************************************

form call_alv.

data: wa_cat like line of alv_fldcat.

do p_flds times.

clear wa_cat.

wa_cat-fieldname = sy-index.

wa_cat-seltext_s = sy-index.

wa_cat-outputlen = '6'.

append wa_cat to alv_fldcat.

enddo.

*Call ABAP List Viewer (ALV)

call function 'REUSE_ALV_GRID_DISPLAY'

exporting

it_fieldcat = alv_fldcat

tables

t_outtab = <dyn_table>.

endform.

-


With best wishes,

Rama.

10 REPLIES 10
Read only

rainer_hbenthal
Active Contributor
0 Likes
1,113

In other words, you want to create an internal table.

Read only

Former Member
0 Likes
1,113

Hi ,

Please Refer this thread .

Edited by: A kumar on Aug 29, 2008 12:12 PM

Read only

Former Member
0 Likes
1,113

hi rainer,

well main aim is to create a dynamic table....

i have created this dynamic table also which has a dynamic structure.(TABLE 1)

i am having other internal table of different known (declared) structure.(TABLE 2)

well my requirement is to map the data from TABLE 2 to TABLE 1.and list TABLE1 (the dynamic table) as output..

please give suggestions,don't give links .

Read only

Former Member
0 Likes
1,113

Hi,

You can use Extracts(Dynamic internal tables).

or

Field-symbols: <it_fs> type any table," internal table

<wa_fs> type any. " work area

Read only

0 Likes
1,113

hi amit,

can u elaborate a bit with some code snippets..

Read only

Former Member
0 Likes
1,113

Field-symbols: <it_fs> type any table," internal table

<wa_fs> type any. " work area

<it_fs> can acquire attributes of any structure.

Actualy they are like pointers in c/c++

e.g.

select * from abc into table <it_fs>.

<it_fs> now will aquire attributes of abc

select * from xyz into table <it_fs>.

<it_fs> now will aquire attributes of xyz

likewise for <wa_fs>

Read only

0 Likes
1,113

hi amit,

************************************************************

select * from abc into table <it_fs>.

<it_fs> now will aquire attributes of abc

select * from xyz into table <it_fs>.

<it_fs> now will aquire attributes of xyz

likewise for <wa_fs>

**************************************************************

My case is:

data it_table2 type table of ty_struct.

select * from xyz into table it_table2.

dynamic table created by stmt:

call method cl_alv_table_create=>create_dynamic_table

is = <it_fs>

now ,how to move data from it_table2 to <it_fs>.

Read only

0 Likes
1,113

Hi

Use:

assign it_table2 to <it_fs>.

Read only

0 Likes
1,113

hi amit,

but both are of different structure.

Read only

Former Member
0 Likes
1,114

Hi,

I think I have the solution for your requirement, just run the code below it will serve your purpose.

type-pools: slis.

field-symbols: <dyn_table> type standard table,

<dyn_wa>.

data: alv_fldcat type slis_t_fieldcat_alv,

it_fldcat type lvc_t_fcat.

selection-screen begin of block b1 with frame title text-001.

parameters: p_flds(5) type c.

selection-screen end of block b1.

start-of-selection.

*build the dynamic internal table

perform build_dyn_itab.

*write 5 records to the alv grid

do 5 times.

perform build_report.

enddo.

*call the alv grid.

perform call_alv.

************************************************************************

*Build_dyn_itab

************************************************************************

form build_dyn_itab.

data: new_table type ref to data,

new_line type ref to data,

wa_it_fldcat type lvc_s_fcat.

*Create fields .

clear wa_it_fldcat.

wa_it_fldcat-fieldname = 'name1'.

wa_it_fldcat-datatype = 'mara-matnr'.

wa_it_fldcat-intlen = 5.

append wa_it_fldcat to it_fldcat .

*

*clear wa_it_fldcat.

wa_it_fldcat-fieldname = sy-index.

wa_it_fldcat-datatype = 'CHAR'.

wa_it_fldcat-intlen = 5.

append wa_it_fldcat to it_fldcat .

*

do p_flds times.

clear wa_it_fldcat.

wa_it_fldcat-fieldname = sy-index.

wa_it_fldcat-datatype = 'CHAR'.

wa_it_fldcat-intlen = 6.

append wa_it_fldcat to it_fldcat .

enddo.

*Create dynamic internal table and assign to FS

call method cl_alv_table_create=>create_dynamic_table

exporting

it_fieldcatalog = it_fldcat

importing

ep_table = new_table.

assign new_table->* to <dyn_table>.

*Create dynamic work area and assign to FS

create data new_line like line of <dyn_table>.

assign new_line->* to <dyn_wa>.

endform.

*********************************************************************

*Form build_report

*********************************************************************

form build_report.

data: fieldname(20) type c.

data: fieldvalue(5) type c.

data: index(3) type c.

field-symbols: <fs1>.

do p_flds times.

index = sy-index.

*Set up fieldvalue

concatenate 'FLD' index into

fieldvalue.

condense fieldvalue no-gaps.

assign component index of structure <dyn_wa> to <fs1>.

<fs1> = fieldvalue.

enddo.

*Append to the dynamic internal table

append <dyn_wa> to <dyn_table>.

endform.

************************************************************************

*CALL_ALV

************************************************************************

form call_alv.

data: wa_cat like line of alv_fldcat.

do p_flds times.

clear wa_cat.

wa_cat-fieldname = sy-index.

wa_cat-seltext_s = sy-index.

wa_cat-outputlen = '6'.

append wa_cat to alv_fldcat.

enddo.

*Call ABAP List Viewer (ALV)

call function 'REUSE_ALV_GRID_DISPLAY'

exporting

it_fieldcat = alv_fldcat

tables

t_outtab = <dyn_table>.

endform.

-


With best wishes,

Rama.