SAP壓縮excel併發送mail案例

来源:https://www.cnblogs.com/Brokenshelltao/archive/2019/08/29/11428539.html
-Advertisement-
Play Games

SAP壓縮excel產生zip文件後作為附件發送mail案例. ...


"SAP壓縮附件

REPORT ZMMR0033_DEL7 .

TYPESBEGIN OF bin_file,
           name TYPE string,
          size TYPE i,
          data TYPE solix_tab,
     END OF bin_file.

DATA: lv_filename TYPE string,
          wa_bindata TYPE bin_file,
          it_bindata TYPE standard TABLE OF bin_file,
          oref_zip TYPE REF TO cl_abap_zip,
          lv_zip_xstring TYPE xstring,
          lv_xstring TYPE xstring,
          lv_xstring2 TYPE xstring,
          lv_path TYPE string,
          it_filetab TYPE filetable,
          ret_code TYPE i,
          v_usr TYPE i,
          v_zip_size TYPE i,
          it_zip_bin_data TYPE STANDARD TABLE OF raw255,
          v_dest_filepath TYPE string.

DATABEGIN OF it_t001 OCCURS 0,
        bukrs     TYPE t001-bukrs,
        butxt     TYPE t001-butxt,
        land1 TYPE t001-LAND1,
        waers TYPE t001-waers,
  END OF it_t001.

  DATA main_text      TYPE bcsy_text.
  DATA: l_c_detal_1  TYPE solix_tab,
        l_detal_1     TYPE so_obj_len,
        l_filename_detal_1 TYPE sood-objdes.

DATA: g_datel_1     TYPE string.
CONSTANTS: gc_tab  TYPE VALUE cl_bcs_convert=>gc_tab,
                    gc_crlf TYPE VALUE cl_bcs_convert=>gc_crlf.

DATA: lv_filesize TYPE i.
DATA: wa_filetab LIKE LINE OF it_filetab.
DATA:  g_mail_address TYPE ad_smtpadr.

SELECTION-SCREEN BEGIN OF BLOCK b3 WITH FRAME TITLE TEXT-b03.
        SELECT-OPTIONS: s_addr FOR g_mail_address NO INTERVALS DEFAULT'[email protected]'.
SELECTION-SCREEN END OF BLOCK b3.

START-OF-SELECTION.
      PERFORM get_data.
      PERFORM DETAIL_DATA_1.
      PERFORM text.
*      PERFORM send_mail2 .
END-OF-SELECTION.

FORM get_data .

  SELECT * FROM t001
    INTO CORRESPONDING FIELDS OF TABLE it_t001 ."UP TO 10 ROWS.

ENDFORM" get_data

FORM DETAIL_DATA_1 .
  CLEAR: g_datel_1.
 DATA: l_line TYPE string.
 DATA:lv_text1(50),
          lv_text2(50),
          lv_text3(50),
          lv_text4(50),
          lv_text5(50).
*--> column header
  CONCATENATE '存儲地點' '工廠' '物料類型'
              INTO l_line SEPARATED BY gc_tab.
*--> 斷行
      CONCATENATE g_datel_1 l_line gc_crlf INTO g_datel_1.
    LOOP AT it_t001.

        lv_text1 = it_t001-bukrs .
        lv_text2 = it_t001-butxt .
        lv_text3 = it_t001-land1 .
        lv_text4 = it_t001-waers .
        lv_text5 = it_t001-bukrs .


    CONCATENATE lv_text1 lv_text2 lv_text3 lv_text4 lv_text5
                          INTO l_line SEPARATED BY gc_tab.
*--> 斷行
          CONCATENATE g_datel_1 l_line gc_crlf INTO g_datel_1.
  ENDLOOP.

  TRY.
      cl_bcs_convert=>string_to_solix(
        EXPORTING
          iv_string   = g_datel_1
          iv_codepage '4103'  "suitable for MS Excel, leave empty
          iv_add_bom  'X'     "for other doc types
        IMPORTING
          et_solix  = l_c_detal_1
          ev_size   = l_detal_1 ).
    CATCH cx_bcs.
      MESSAGE e445(so).
  ENDTRY.

ENDFORM.

FORM text" 壓縮文件

    DATA: l_send_request  TYPE REF TO cl_bcs,
        l_zip           TYPE REF TO cl_abap_zip,
        l_sender        TYPE REF TO cl_sapuser_bcs,
        l_recipient     TYPE REF TO cl_cam_address_bcs,
        l_body_text     TYPE bcsy_text,
        l_obj_len       TYPE so_obj_len,
        l_subject       TYPE so_obj_des,
        l_exception     TYPE REF TO cx_bcs,
        l_message       TYPE string,
        l_content       TYPE solix_tab,
        l_html_xstr     TYPE xstring,
        l_zip_xstr      TYPE xstring,
        l_len           TYPE i,
        l_document      TYPE REF TO cl_document_bcs.

 DATA: lv_codepage(4TYPE n,
           l_encoding(20),
           xstr TYPE xstring.
*           get_buffer TYPE buffer.

" create object
  CREATE OBJECT oref_zip.


DO TIMES.  " 產生本地 zip 附件 及zip mail轉換用
   wa_bindata-data = l_c_detal_1.
   wa_bindata-size = l_detal_1.
   wa_bindata-name 'aa.xls'.
      APPEND wa_bindata TO it_bindata.
ENDDO.

    "將文件換換為xstring 
     CALL FUNCTION 'SCMS_BINARY_TO_XSTRING'
    EXPORTING
      input_length = wa_bindata-size
     IMPORTING
       buffer = lv_xstring
       TABLES
       binary_tab = wa_bindata-data
      
      
     CALL FUNCTION 'SCMS_BINARY_TO_XSTRING'
    EXPORTING
      input_length = wa_bindata-size
     IMPORTING
       buffer = lv_xstring2
       TABLES
       binary_tab = wa_bindata-data" 可替換為其他不同data
     
    "1. 產生本端zip   
    "2.zip mail 可省略以下代碼 
    oref_zip->add( name = wa_bindata-name
            content = lv_xstring ).

*****************************本端 zip ************************************
*-----> 保存附件到壓縮文件夾
  lv_zip_xstring = oref_zip->save).
  CALL FUNCTION 'SCMS_XSTRING_TO_BINARY'
  EXPORTING
    buffer = lv_zip_xstring
  IMPORTING
      output_length = v_zip_size
   TABLES
     binary_tab = it_zip_bin_data.

*****************************************************
* 選擇路徑保存文件
  cl_gui_frontend_services=>file_save_dialog(
  EXPORTING
    window_title 'SELECT THE LOCATING TO SAVE THE FILE'
    file_filter '(*.zip)|*.ZIP|'
    CHANGING
      filename = lv_filename
      path = lv_path
      fullpath = v_dest_filepath ).
**
** 試圖替換文件
    cl_gui_frontend_services=>gui_download(
    EXPORTING
      bin_filesize = v_zip_size
      filename = v_dest_filepath
      filetype 'BIN'
      IMPORTING
        filelength =  lv_filesize
        CHANGING
          data_tab  = it_zip_bin_data ).
**************************************end 本端 zip *********************

  TRY.

      l_send_request = cl_bcs=>create_persistent).
      l_subject '壓縮文件名稱'.
      APPEND:  '<HTML><BODY>'                                              TO l_body_text,
                 'Hi,'                                                     TO l_body_text,
                 '<p>Pls refer to the attached. Thanks.'                   TO l_body_text,
               '</BODY><HTML>'                                             TO l_body_text.
      l_document = cl_document_bcs=>create_document(
                            i_type        'HTM'
                            i_text        = l_body_text
                            i_subject     = l_subject
                    ).

*" 設置編碼格式
* CALL FUNCTION 'SCP_CODEPAGE_BY_EXTERNAL_NAME'
*  EXPORTING
*    external_name = 'UTF-8'
*  IMPORTING
*    sap_codepage  = lv_codepage.
*
*   l_encoding = lv_codepage.
*
*   DATA: convout TYPE REF TO cl_abap_conv_out_ce.
*      " 創建編碼對象
*   convout = cl_abap_conv_out_ce=>create( encoding = l_encoding ).
**   convout->write( data = g_datel_1 )."編碼
*   convout->write( data = g_datel_1 )."編碼
*   xstr = convout->get_buffer( )." 獲取流碼
*
*   DATA: convin TYPE REF TO cl_abap_conv_in_ce.
*   convin = cl_abap_conv_in_ce=>create( encoding = l_encoding input = xstr ).
*   DATA: str TYPE string.
*   CALL METHOD convin->read
*      importing data = str.
*
*      call function 'SCMS_STRING_TO_XSTRING'
*      exporting
*      text = str "g_datel_1
**       MIMETYPE = ' '
*      importing
*      buffer = l_html_xstr
*      exceptions
*      failed = 1
*      others = 2.       

CREATE OBJECT l_zip.       
CALL METHOD l_zip->add         
EXPORTING           name    
'1111.xls'" 壓縮附件名稱  在這裡不要用中文命名,會亂碼           content 
= lv_xstring."l_html_xstr.              

CALL METHOD l_zip->add         
EXPORTING           name    
'2222.xls'" 壓縮附件名稱  在這裡不要用中文命名,會亂碼           content 
= lv_xstring2.       

CALL METHOD l_zip->save         RECEIVING           zip 

= l_zip_xstr.       

CALL METHOD cl_bcs_convert=>xstring_to_solix         
EXPORTING           iv_xstring 
=  l_zip_xstr "lv_xstring         RECEIVING           et_solix   

= l_content.        l_obj_len 

XSTRLEN( l_zip_xstr ."lv_xstring ).

CALL METHOD l_document->add_attachment         
EXPORTING           i_attachment_size    
= l_obj_len           i_attachment_type    
'ZIP'           i_attachment_subject 
= l_subject           i_att_content_hex    
= l_content.       l_send_request
->set_document( l_document ).       l_sender 
= cl_sapuser_bcs=>create( sy-uname ).       
LOOP AT s_addr.         l_recipient 
= cl_cam_address_bcs=>create_internet_address( s_addr-low ).         
CALL METHOD l_send_request->add_recipient           
EXPORTING             i_recipient 
= l_recipient.       
ENDLOOP.       
CALL METHOD l_send_request->set_send_immediately'X' ).       
CALL METHOD l_send_request->send(       
EXPORTING         i_with_error_screen  
'X'         
).       
COMMIT WORK.     
CATCH cx_bcs INTO l_exception.       l_message 
= l_exception->get_text).       
MESSAGE l_message TYPE 'E'.   
ENDTRY.  

ENDFORM

以上excel是以上案例是以下博友合併後原創.如有更好的方法及bug問題請聯繫作者,謝謝

https://www.cnblogs.com/StephenAmell/p/10278351.html “excel作為附加發送至郵件”

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • $.ajax 完整參數 jquery中的ajax方法參數 url: 要求為String類型的參數,(預設為當前頁地址)發送請求的地址。 type: 要求為String類型的參數,請求方式(post或get)預設為get。註意其他http請求方法,例如put和delete也可以使用,但僅部分瀏覽器支持 ...
  • 一、 Vue 的介紹 1. vue是一個 mvvm 的框架。(面試官經常會問的),angular 是 mvc的框架。 2. vm 是 vum 的實例,這個實例存在電腦記憶體中,主要乾兩件大事: 1. 綁定數據 2. dom檢測 3. vue 實例 靠 new 關鍵字實例化 vue 對象,使用 mvv ...
  • 微信小程式的功能變數名稱需要備案,但是沒有大陸的伺服器,而且覺得備案有些繁瑣,起初做的小程式都有點想要放棄了,後來瞭解到騰訊雲的雲函數,於是利用騰訊雲的雲函數實現了一個簡單的 API 網關,通過雲函數來調用真正的 API 地址,藉此來繞過功能變數名稱備案的問題。 ...
  • 前言 前陣子有網友詢問,如何優化網站?這個問題真的很大,跟他簡單的聊了一下,隨便說了幾點,覺得有必要整理一篇文章出來,正好前陣子在做爬蟲博客,於是把大體思路分享出來,與大家互通有無,共同進步。 優化 版本一 系統開始是這樣子的,一個 Tomcat 拖著一個 MySql 服務,跑在一個 2C 4G 的 ...
  • 偷偷和你們說,我搞了一份內部資料,該內部資料共有13張PPT,據作者透露,該PPT至少花了整整1周時間才編寫完成,其內容簡潔明瞭,內容深度足夠,易於初學者理解,也給深度開發人員分享了不一樣的消息隊列的玩法。特別重要的是,該架構目前已大面積的穩定應用於生產環境。 ...
  • Python 入門之 文件 1、文件操作 找到文件位置 雙擊打開 進行一些操作 r—read(讀) w—write(寫) a—追加 rd 讀位元組 wd 清空寫,寫位元組 ad 追加寫(位元組) r+ 讀寫 w+ 寫讀 a+ 追加讀 關閉文件 open() : 打開 ,open通過python控制操作系統 ...
  • 壓測的時候,經常需要使用動態參數,即每次請求的參數不一樣,這樣才能更好的模擬真實的用戶請求 我們首先能想到的也是最常見的就是用戶ID 1. 用戶參數 我們可以定義一個變數,然後指定多個值,這樣每次請求的時候都會順序迴圈去取這些值。通過${variable}取值。 具體參見官方文檔,上面寫的比較詳盡, ...
  • Java I/O文件 文件記憶體 》程式 》記憶體鍵盤 控制台 文件 什麼是文件? 相關記錄或放在一起的數據的集合 文件一般存儲在哪裡? 磁碟,u盤,移動硬碟 Java程式如何訪問文件屬性? JAVA API:java.io.File類 File類訪問文件屬性 File類 》創建文件對象 》操作文件或目 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...