MUNDOSAP

MUNDOSAP (foro/index.php)
-   Programación ABAP IV (foro/forumdisplay.php?f=4)
-   -   Duda tabla interna (foro/showthread.php?t=72163)

roberto.mejia 27/07/14 19:26:35

Duda tabla interna
 
Hola gente del foro:

Tengo la siguiente duda, tengo la tabla interna tipo tabla sp y mi duda es si se puede imprimir los datos de dicha tabla sin necesidad de especificar que campos quiere que se muestre o sea mostrar todos los datos.

TABLES: sflight.

TYPES: BEGIN OF spflig.
INCLUDE STRUCTURE sflight.
TYPES: END OF spflig.

DATA: sp TYPE TABLE OF spflig WITH HEADER LINE.

SELECT * INTO CORRESPONDING FIELDS OF TABLE sp FROM sflight.


LOOP at sp.
WRITE / sp-carrid. " si pongo write sp me sale error no se puede convertir "en un campo alfanumerico
ENDLOOP.

Spainnavar 28/07/14 08:11:03

ALV y fieldcat
 
Te puedes crear un ALV. El fieldcat lo puedes construir automáticamente con la función REUSE_ALV_FIELDCATALOG_MERGE. En i_structure metele la tabla "modelo" (en tu caso seria la sflight) y en la salida tendras tu fieldcat construido.

Espero que te sirva,
Un saludo

roberto.mejia 29/07/14 05:00:51


Hola, hice lo que me dijiste, éste es mi código:

types: begin of spflig.
include structure sflight.
types: end of spflig.

data: sp type table of spflig with header line.

select * into corresponding
fields of table
sp from sflight.


type-pools: slis.
data int_fcat type
slis_t_fieldcat_alv.

call function 'REUSE_ALV_FIELDCATALOG_MERGE'
exporting
i_program_name = sy-repid
i_internal_tabname = 'sp'
i_inclname = sy-repid
changing
ct_fieldcat = int_fcat.

call function 'REUSE_ALV_GRID_DISPLAY'
exporting
it_fieldcat = int_fcat
tables
t_outtab = sp.

me sale que no es posible determinar un catálogo de campo. ayuda

Spainnavar 29/07/14 07:29:31

En structure tienes que mter la tabla de datos (transparente) que quieras usar como modelo para el fieldcat. Las demás entradas yo nunca las he usado y asi me ha fucionado correctamente. Eso si, siempre me ha funcionado con tablas trnasparentes Z, pero supongo que con las Standard también valdra. Seria algo asi:

CALL FUNCTION 'REUSE_ALV_FIELDCATALOG_MERGE'
EXPORTING
i_structure_name = 'SFLIGHT' " Nombre tabla transparente modelo, los nombres entre comillas sieeeeempre con mayúscula ;)
CHANGING
ct_fieldcat = int_fcat
EXCEPTIONS
inconsistent_interface = 1
program_error = 2
OTHERS = 3.

Luego llama al ALV como lo has hecho.

roberto.mejia 29/07/14 21:09:09


Gracias me salió, y si quisiera hacer con 2 tablas z por ejemplo spfli y sflight sería i_structure_name = 'SFLIGHT', 'SPFLI' ?

Y si también quiero sólo mostrar algunos campos lo tendría que hacer de la forma manual diciendo campo por campo ? parecido a lo de abajo :

CLEAR ti_fieldcat.
ti_fieldcat-fieldname = 'CARRID'.
ti_fieldcat-tabname = 'TI_TABLA'.
ti_fieldcat-seltext_m = 'CARRID'.
ti_FIELDCAT-EMPHASIZE = 'C710'.
ti_fieldcat-col_pos = 0.
ti_fieldcat-row_pos = 1.
ti_fieldcat-OUTPUTLEN = 255.
APPEND ti_fieldcat.

CLEAR ti_fieldcat.
ti_fieldcat-fieldname = 'CITYFROM'.
ti_fieldcat-tabname = 'TI_TABLA'.
ti_fieldcat-seltext_s = 'CIUDAD'. " descripcion corta
ti_fieldcat-seltext_l = 'CIUDAD GRANDE'. " descripcion larga
ti_fieldcat-seltext_m = 'CIUDAD MED'. " descripcion media
ti_fieldcat-outputlen = 8.
ti_fieldcat-col_pos = 3.
ti_fieldcat-row_pos = 2.
APPEND ti_fieldcat.

Spainnavar 30/07/14 07:09:53

Si quisieras hacerlo con dos estructuras deberías hacer... una estructura en int_fcat y otra estructura en int_fcat2 (llamando dos veces distintas a la función) y luego hacer un LOOP de int_fcat2 e ir haciendo APPENDs a la int_fcat. Pero igual algún campo lo tienes común, deberías vigilar que no se repitan.

Sí, si son solo 2 campos deberías meterlos a mano. y si por ejemplo son todos los campos de la estructura menos 1, pues deberías marcar el campo NO_OUT (o algo asi, ahora mismo no recuerdo exactamente) para el que no deseas mostrar.

Después puedes ir jugando con las opciones de los campos que te da el fieldcat, que a veces salvan la vida.

Si tienes cualquier duda mas, coméntame,

Un saludo ;)


Husos Horarios son GMT. La hora en este momento es 05:25:05.

www.mundosap.com 2006 - Spain
software crm, crm on demand, software call center, crm act, crm solutions, crm gratis, crm web