Hola,
Revisa el enlace,
http://www.sapdevelopment.co.uk/reporting/email/attachhome.htm
Saludos,
Azaz Ali.
Avalados por :
Tengo que escribir algunas rutinas ABAP en BW.
A continuación se presenta el escenario:
Leyendo registros del paquete de solicitud, almacenándolos en alguna tabla interna, y luego llamando a alguna FM para almacenar en una hoja de Excel, y luego enviando esa hoja de Excel por correo externo.
¿Cuáles son los módulos de función para guardar la salida en formato Excel y enviar el archivo por correo electrónico?
Hola,
Revisa el enlace,
http://www.sapdevelopment.co.uk/reporting/email/attachhome.htm
Saludos,
Azaz Ali.
Puedes usar SO_DOCUMENT_SEND_API1 para enviar adjuntos de Excel.
Aquí tienes un código de ejemplo para enviar un archivo de Excel como adjunto.
report ZMAILTEST.
parameters: p_email type somlreci1-receiver
default 'you@yourcompany.com'.
data: begin of it001 occurs 0,
bukrs type t001-bukrs,
butxt type t001-butxt,
end of it001.
data: imessage type standard table of solisti1 with header line,
iattach type standard table of solisti1 with header line,
ipacking_list like sopcklsti1 occurs 0 with header line,
ireceivers like somlreci1 occurs 0 with header line,
iattachment like solisti1 occurs 0 with header line.
start-of-selection.
select bukrs butxt into table it001 from t001.
Llena la tabla con detalles para ser ingresados en el archivo .xls
perform build_xls_data .
Llena el cuerpo del mensaje
clear imessage. refresh imessage.
imessage = 'Por favor, encuentra adjunto el archivo de Excel'.
append imessage.
Envía el archivo por correo electrónico como hoja de cálculo .xls
perform send_email_with_xls tables imessage
iattach
using p_email
'Ejemplo de Adjunto de Excel'
'XLS'
'NombreArchivoPrueba'
'Códigos de Compañía'.
form build_xls_data .
constants: con_cret type x value '0D', "OK para no Unicode
con_tab type x value '09'. "OK para no Unicode
concatenate 'BUKRS' 'BUTXT'
into iattach separated by con_tab.
concatenate con_cret iattach into iattach.
loop at it001.
concatenate it001-bukrs it001-butxt
into iattach separated by con_tab.
concatenate con_cret iattach into iattach.
append iattach.
endloop.
endform.
form send_email_with_xls tables pit_message
pit_attach
using p_email
p_mtitle
p_format
p_filename
p_attdescription.
data: xdocdata like sodocchgi1,
xcnt type i.
xdocdata-doc_size = 1.
xdocdata-obj_langu = sy-langu.
xdocdata-obj_name = 'SAPRPT'.
xdocdata-obj_descr = p_mtitle .
clear xdocdata.
read table iattach index xcnt.
xdocdata-doc_size =
( xcnt - 1 ) * 255 + strlen( iattach ).
xdocdata-obj_langu = sy-langu.
xdocdata-obj_name = 'SAPRPT'.
xdocdata-obj_descr = p_mtitle.
clear iattachment. refresh iattachment.
iattachment[] = pit_attach[].
clear ipacking_list. refresh ipacking_list.
ipacking_list-transf_bin = space.
ipacking_list-head_start = 1.
ipacking_list-head_num = 0.
ipacking_list-body_start = 1.
describe table imessage lines ipacking_list-body_num.
ipacking_list-doc_type = 'RAW'.
append ipacking_list.
ipacking_list-transf_bin = 'X'.
ipacking_list-head_start = 1.
ipacking_list-head_num = 1.
ipacking_list-body_start = 1.
describe table iattachment lines ipacking_list-body_num.
ipacking_list-doc_type = p_format.
ipacking_list-obj_descr = p_attdescription.
ipacking_list-obj_name = p_filename.
ipacking_list-doc_size = ipacking_list-body_num * 255.
append ipacking_list.
clear ireceivers. refresh ireceivers.
ireceivers-receiver = p_email.
ireceivers-rec_type = 'U'.
contacto@primeinstitute.com
(+51) 1641 9379
(+57) 1489 6964
© 2024 Copyright. Todos los derechos reservados.
Desarrollado por Prime Institute