MUNDOSAP

MUNDOSAP (foro/index.php)
-   Programación ABAP IV (foro/forumdisplay.php?f=4)
-   -   grabar smartforms en pdf (foro/showthread.php?t=35129)

zebalia 12/02/10 10:30:02

grabar smartforms en pdf
 
Hola, tengo creado un smartform y me piden que en vez de salir los parámetros de impresión, se genere directamente un pdf.

Como puedo hacerlo?

Tengo entendido que tengo que poner en FORM ATTRIBUTES, la opción de Output Format: XSF Output, pero no tengo ni idea.

Alguien me puede echar una mano?

Gracias

ppchico 12/02/10 10:44:47

Creo que puedes generar un documento PDF con el SMARTFORMS... hay unas funciones especificas para ello, y generas una tabla con formato XSTRING, que puedes descargar al PC. Busca *PDF* en la transacción SE37, y busca el módulo de función que te interese. Suerte!

Neo_25 12/02/10 11:40:20

A ver si te sirve. Yo es lo q uso.

************************************************************* S M A R T F O R M
**********************************************************
***---------------------------------------------------------
*** Configuración y creación del smartform
***---------------------------------------------------------
**-------------------
** variables para sacar los datos del smartform
**-------------------
*DATA:
* lfm_name TYPE rs38l_fnam,
* lw_ctrlop TYPE ssfctrlop,
* lw_compop TYPE ssfcompop,
* lw_return TYPE ssfcrescl,
* li_otf TYPE itcoo OCCURS 0 WITH HEADER LINE,
* lv_len_in TYPE i,
* li_tline TYPE TABLE OF tline WITH HEADER LINE.
*
*
******
** OBTENEMOS LOS DATOS DEL SMARTFORM
******
** llamo a mi smartform ZSGCF0001
*CALL FUNCTION 'SSF_FUNCTION_MODULE_NAME'
* EXPORTING
* formname = 'ZSGCF0001' "nombre del smartform
* IMPORTING
* fm_name = lfm_name
* EXCEPTIONS
* no_form = 1
* no_function_module = 2
* OTHERS = 3.
*IF sy-subrc <> 0.
* MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
* WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
*ENDIF.
*
** para no verlo y que se marquen solos algunos botones
** para que se mande imprimir directamente
*lw_ctrlop-getotf = 'X'. "Retorno tab.OTF. Sin imprimir, visualizar
*lw_ctrlop-no_dialog = 'X'.
*lw_compop-tddest = 'LOCA'. "impresora local
*
** variables de entrada y salida para el smartform
*CALL FUNCTION lfm_name
* EXPORTING
* control_parameters = lw_ctrlop
* output_options = lw_compop
* user_settings = ' ' "tiene q estar con el espacio para q no salga la ventanita de impresión
* e_task = pi_e_task
* e_object = pi_e_object
* i_estimation = pi_i_estimation
* i_text_detail = pi_i_text_detail
* IMPORTING
* job_output_info = lw_return
* EXCEPTIONS
* formatting_error = 1
* internal_error = 2
* send_error = 3
* user_canceled = 4
* OTHERS = 5.
*IF sy-subrc <> 0.
* MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
* WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
*ENDIF.
*
*li_otf[] = lw_return-otfdata[].
*
*
******
** Obtengo el PDF en una tabla interna
******
*CALL FUNCTION 'CONVERT_OTF'
* EXPORTING
* format = 'PDF'
* max_linewidth = 132
* IMPORTING
* bin_filesize = lv_len_in
* TABLES
* otf = li_otf[]
* lines = li_tline
* EXCEPTIONS
* err_max_linewidth = 1
* err_format = 2
* err_conv_not_possible = 3
* err_bad_otf = 4
* OTHERS = 5.
*IF sy-subrc <> 0.
* MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
* WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
*ENDIF.

zebalia 12/02/10 12:09:22


Y donde me genera el fichero?

Gracias muy util!

ppchico 12/02/10 12:17:22

En este caso, tienes la tabla con el fichero, solo tendrías que descargarlo al PC, con el módulo de funciones GUI_DOWNLOAD. Puedes mirar el REPORT ESTÁNDAR RSTXPDFT que pasa los textos estándar a PDF y los descargas.

Neo_25 12/02/10 12:33:41

Bueno, ya completo.
Lo bajarías así:

*****
* LO BAJAMOS AL PC --> C:\TEMP\
*****
** convierto la tabla interna del PDF a PDF en el disco duro "C:\TEMP\PDFEMAIL.PDF"
* CALL FUNCTION 'GUI_DOWNLOAD'
* EXPORTING
* bin_filesize = lv_len_in
* filename = lv_ruta_fich
* filetype = 'BIN'
* TABLES
* data_tab = li_tline
* EXCEPTIONS
* file_write_error = 1
* no_batch = 2
* gui_refuse_filetransfer = 3
* invalid_type = 4
* no_authority = 5
* unknown_error = 6
* header_not_allowed = 7
* separator_not_allowed = 8
* filesize_not_allowed = 9
* header_too_long = 10
* dp_error_create = 11
* dp_error_send = 12
* dp_error_write = 13
* unknown_dp_error = 14
* access_denied = 15
* dp_out_of_memory = 16
* disk_full = 17
* dp_timeout = 18
* file_not_found = 19
* dataprovider_exception = 20
* control_flush_error = 21
* OTHERS = 22.
*
* IF sy-subrc <> 0.
* MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
* WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
* ENDIF.

zebalia 12/02/10 17:53:05



Chicos, os debo una, muchas gracias.

El lunes lo pruebo en el curro y os cuento.

Saludos

zebalia 15/02/10 07:52:26

Gracias de nuevo, lo acabo de probar y funciona perfectamente.

Solo tengo un pequeño problemilla. Me gustaría que el fichero lo guardase en un directorio de sap, en concreto un directorio que se llama DIR_INFORMES. Si me fijo en la ruta de este directorio, se llama /usr/sap/blablabla/blablabla.

Como puedo hacer para pasarle ese directorio de SAP ?

Muchisimas gracias

Neo_25 15/02/10 08:38:58

La variable local lv_ruta_fich es del tipo q sea filename.
Y le metes a lv_ruta_fich = '/usr/sap/blablabla/blablabla'.

* filename = lv_ruta_fich 'C:\temp\Sentencias.pdf' "R U T A

prueba a ver así.

zebalia 15/02/10 09:38:35

Si, es lo que hice, pero esa ruta no me la reconoce, ya que no está en mi ordenador, sino que es una ruta de SAP que a saber donde está realmente.

De todos modos, lo he hablado con mi jefe y me ha dicho que puedo grabar el fichero en local, siempre que se le de la posibilidad al usuario de elegir la ruta (una especie de explorador vamos...).

Sabeis si hay alguna propiedad o matchcode que permita abrir el explorador y seleccionar una ruta? Si no, le diré que ponga la ruta a pelo, aunque es un poco feo...

Gracias por vuestra ayuda.

Neo_25 15/02/10 09:55:00

Prueba esto:

*En P_FILE va a quedar guardada la ruta del archivo
PARAMETERS: p_file TYPE LOCALFILE. "Fichero local para upload/download

*Llamamos a la función que abre el browser apretando el matchcode
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_file.
CALL FUNCTION 'F4_FILENAME'
EXPORTING
program_name = sy-repid
dynpro_number = sy-dynnr
field_name = 'path'
IMPORTING
file_name = p_file.

Neo_25 15/02/10 10:02:43

Donde lo tienes q subir es una ruta del servidor?

zebalia 15/02/10 10:07:21



Eso mismo le he preguntado pero no me ha sabido responder. Me dice que es un directorio de SAP pero no se donde está fisicamente. Solo se que con la transacción AL11 puedo ver dicho directorio y tiene esa ruta "usr/sap/blablabla...."

De todos modos, voy a probar eso del machtcode que me has puesto, que además tengo que hacer unos cuantos para ciertos campos...a ver si investigo porque no he hecho uno en mi vida :(

Gracias por tu tiempo Neo

Neo_25 15/02/10 10:39:20

Me pillas q tengo poca cosa q hacer, y q lo q estás haciendo lo he hecho más o menos, porque yo llevo poco tiempo con SAP.

Eso de la AL11 lo hice yo y es subirlo al servidor de SAP, te pongo el código q yo usé:

* Tabla interna donde guardaremos el fichero txt
DATA: i_txt TYPE ty_tab_txt.
DATA: w_ruta TYPE localfile.

PERFORM f_subir_txt_a_servidor USING i_txt
w_ruta.

*&---------------------------------------------------------------------*
*& Form F_SUBIR_TXT_A_SERVIDOR
*&---------------------------------------------------------------------*
* Subimos el fichero txt al servidor
*----------------------------------------------------------------------*
* -->PI_TXT Tabla que contiene todas las líneas a subir
* -->PI_RUTA Ruta donde guardar el fichero txt
*----------------------------------------------------------------------*
FORM f_subir_txt_a_servidor USING pi_txt TYPE ty_tab_txt
pi_ruta TYPE localfile.

FIELD-SYMBOLS: <fs_txt> TYPE ty_tyl_txt.

* si el fichero no existe lo crea
* con el appending añadimos al fichero más líneas, es decir
* la 1ª vez se meten 50 líneas,
* la 2ª vez habría 100 (50 + 50)
* no crea otro fichero nuevo, ni machaca al q ya existe

OPEN DATASET pi_ruta FOR APPENDING IN TEXT MODE ENCODING DEFAULT.
IF sy-subrc = 0.
LOOP AT pi_txt ASSIGNING <fs_txt>.
TRANSFER <fs_txt> TO pi_ruta.
ENDLOOP.
CLOSE DATASET pi_ruta.
IF sy-subrc <> 0.
MESSAGE e999(pp) WITH text-003 pi_ruta. "mal cerrado
ENDIF.
ELSE.
MESSAGE e999(pp) WITH text-002 pi_ruta. "mal abierto
ENDIF.

ENDFORM. " F_SUBIR_TXT_A_SERVIDOR

zebalia 15/02/10 10:55:11

Pero mi fichero es un pdf...me dejará igualmente?? Es que lo de escritura por el final en un pdf... dudo mucho que me deje

Voy a probar

zebalia 15/02/10 11:27:44

Nada tio, no me tira... no me queda claro donde le pongo el nombre del fichero. Me imagino que en la propia ruta no?

Neo_25 15/02/10 11:38:28

Si, en la propia ruta y le dices q extensión es.

Yo creo q usé este código para subir un fichero txt al servidor.

No te vale lo de abrir una ventana e indicar donde s ebaja?

zebalia 16/02/10 11:46:10



Al final lo he hecho con una ventana. Gracias Neo, no lo habría conseguido sin tu ayuda ;)

Neo_25 16/02/10 14:19:04

De nada,
a mí también me viene bien cuando me ponen el código.

Si podrías explicar un poco lo de la ventana o poner el código.

Hasta otra.

zebalia 17/02/10 10:42:15

Si, yo he usado los siguientes forms para sacar la ventanita.

**************FORMS
*---------------------------------------------------------------------*
* FORM GET_FILE_OUT
*---------------------------------------------------------------------*
FORM get_file_out USING value(p_type) value(p_path)
CHANGING filename p_pc.
PERFORM get_file_in_out USING p_type p_path 'S'
CHANGING filename p_pc.
ENDFORM. " GET_FILE_OUT

*---------------------------------------------------------------------*
* FORM GET_FILE_in_out
*---------------------------------------------------------------------*
FORM get_file_in_out USING value(p_type) value(p_path) value(mode)
CHANGING filename p_pc.
DATA:
* mode VALUE 'S' , "Save mode
* mode VALUE 'O' , "Open mode
mask(120) ,
title(19).
title = 'Localizar fichero'.
IF p_type = 'ASC'.
mask = ',PDF,*.PDF.'.
"mask = ',PDF,*.pdf'.
ELSE.
* mask = ',TRACM ASC,*.ASC,TRACM SDF,*.SDF.'.
mask = ',*,*,BIN,*.bin,*.PDF.'.
"mask = ',*,*,BIN,*.bin,PDF,*.pdf.'.
ENDIF.

* WINDOW STARTING AT 1 25 ENDING AT 12 45.

CALL FUNCTION 'WS_FILENAME_GET'
EXPORTING
* DEF_FILENAME = ' '
def_path = p_path
mask = mask
mode = mode
title = title
IMPORTING
filename = filename
* RC =
EXCEPTIONS
inv_winsys = 01
no_batch = 02
selection_cancel = 03
selection_error = 04.

CASE sy-subrc.
WHEN 0.
* message s899.
p_pc = 'X'. "c_ftp_marcado.
WHEN 1.
MESSAGE ID '00' TYPE 'E' NUMBER '398' WITH
'Error nº '(915) sy-subrc
' Introduzca el nombre correcto '(916)
' No es posible ayuda selección '(917).
WHEN 2.
MESSAGE ID '00' TYPE 'E' NUMBER '398' WITH
'Error nº '(015) sy-subrc
' Introduzca el nombre correcto '(916)
' No es posible ayuda selección '(917).
WHEN 3.
MESSAGE ID '00' TYPE 'S' NUMBER '398' WITH
'Cancelación de selección de ficheros'(918).
WHEN 4.
MESSAGE ID '00' TYPE 'E' NUMBER '398' WITH
'Error nº'(915) sy-subrc.
ENDCASE.
ENDFORM.







Despues de todo esto, he puesto esto para llamar a la ventana.

PARAMETERS: p_fich LIKE rlgrap-filename OBLIGATORY, "Fichero de texto
p_pc AS CHECKBOX default 'X'.


AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_fich.

* Ayuda para localizar los itabs locales.
PERFORM get_file_out USING 'ASC' 'C:\*.*'
CHANGING p_fich p_pc.

crounly 17/02/10 14:23:42

Si quieres conseguir la ruta de un directorio de SAP en la AL11 puedes usar este código:

DATA: server_dir TYPE DIRPROFILENAMES,
dir_al11 TYPE TYPE DIRNAME_AL11

CALL 'C_SAPGPARAM' ID 'NAME' FIELD server_dir
ID 'VALUE' FIELD dir_al11.

EJ: si el nombre en la AL11 es DIR_TMP, en dir_al11 tendras la ruta asociada a ese nombre.

crounly 17/02/10 14:31:24

Para desde la pantalla de seleccion te salte el explorador


SELECTION-SCREEN BEGIN OF BLOCK BLOCK02 WITH FRAME TITLE TEXT-S02.
PARAMETERS: f1 like RLGRAP-FILENAME OBLIGATORY DEFAULT 'C:\',
SELECTION-SCREEN END OF BLOCK BLOCK02.

* Ayudas, lanzar el explorador
AT SELECTION-SCREEN ON VALUE-REQUEST FOR f1.
PERFORM SET_filepath changing f1.

*&---------------------------------------------------------------------*
*& Form SET_filepath
*&---------------------------------------------------------------------*
* text
*----------------------------------------------------------------------*
* <--P_F1 text
*----------------------------------------------------------------------*
FORM SET_filepath CHANGING P_F1.

data : fullpath TYPE string,
l_usract TYPE i.

CALL FUNCTION 'GUI_FILE_SAVE_DIALOG'
EXPORTING
WINDOW_TITLE = 'Explorardor de windows'
DEFAULT_EXTENSION = 'txt'
DEFAULT_FILE_NAME = 'Prueba'
IMPORTING
FULLPATH = fullpath
USER_ACTION = l_usract
.

if l_usract <> 9.
p_f1 = fullpath.
endif.
ENDFORM. " SET_filepath

PD: lo siento , pero no me deja incluir las etiquetas de código....

leonel.vedo 22/02/12 17:12:29



Yo tengo un smartform y hay un reporte el cual lo utiliza. Lo que yo debo hacer es agregarle la opcion de guardarlo en un .PDF.
Lo hace pero el pdf que me genera posee letras muy pegadas, casi superpuestas y dibuja lineas donde no deberia.
Agradeceria cualquier sugerencia.
Gracias

Juan Pablo Andujar 24/02/12 21:17:12

PDFs en SAP
 
Hay varias maneras de generar PDF's desde SAP, sobrtodo desde Smartforms. Fijate si te sirve este link EN CASTELLANO, que explica en las opciones en general



o si no este que es más detallado




Suerte!

Ariel-StaFe 09/04/12 16:06:29

Consulta
 
Neo_25:
Como estas.. en una de tus respusetas - declaraciones.. declaras
FIELD-SYMBOLS: <fs_txt> TYPE ty_tyl_txt.
Me podrias dar la declaracion de ty_tyl_txt ?
Muchisimas gracias


Husos Horarios son GMT. La hora en este momento es 21:17:49.

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