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 |
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!
|
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. |
Y donde me genera el fichero? Gracias muy util! |
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.
|
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. |
Chicos, os debo una, muchas gracias. El lunes lo pruebo en el curro y os cuento. Saludos |
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 |
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í. |
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. |
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. |
Donde lo tienes q subir es una ruta del servidor?
|
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 |
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 |
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 |
Nada tio, no me tira... no me queda claro donde le pongo el nombre del fichero. Me imagino que en la propia ruta no?
|
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? |
Al final lo he hecho con una ventana. Gracias Neo, no lo habría conseguido sin tu ayuda ;) |
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. |
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. |
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. |
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.... |
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 |
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! |
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 12:03:08. |
www.mundosap.com 2006 - Spain
software crm, crm on demand, software call center, crm act, crm solutions, crm gratis, crm web