SAP中文件的上传和下载

在SAP中上传文件我知道的有两种方法。
1、可以使用SMW0事务码。
2、写代码实现。
DATA:lt_file TYPE filetable WITH HEADER LINE,
           rec TYPE i.
  DATA: l_filter TYPE string.
* 选择上传文件
  CONCATENATE cl_gui_frontend_services=>filetype_excel
                          cl_gui_frontend_services=>filetype_all
                 INTO l_filter.
  CALL METHOD cl_gui_frontend_services=>file_open_dialog
    EXPORTING
      window_title            = 'Upload Excel'
*     default_extension       = '.xls'
*     default_filename        =
      file_filter             = l_filter
      initial_directory       = 'C:\'
    CHANGING
      file_table              = lt_file[]
      rc                      = rec
    EXCEPTIONS
      file_open_dialog_failed = 1
      cntl_error              = 2
      error_no_gui            = 3
      not_supported_by_gui    = 4
      OTHERS                  = 5.
  IF  rec >= 1.
    READ TABLE lt_file INDEX 1.
    p_file = lt_file-filename.
  ELSEIF rec = 0.
    CLEAR p_file.
  ELSE.
    MESSAGE e000 WITH text-e01.
  ENDIF.
 
下载文件就没那么方便要Coding了,代码如下
 
DATA:lc_table TYPE filetable,
            l_rc       TYPE i,
            l_file      LIKE rlgrap-filename.
  FIELD-SYMBOLS: TYPE file_table .
  DATA: l_string TYPE string.
  DATA: obj_name LIKE wwwdatatab-objid.
  DATA: objdata LIKE wwwdatatab,
             rc LIKE sy-subrc.
  CALL METHOD cl_gui_frontend_services=>file_open_dialog
    EXPORTING
      window_title            = g_filetitle
      file_filter             = g_filefilter
      initial_directory       = g_initdir
    CHANGING
      file_table              = lc_table
      rc                      = l_rc
    EXCEPTIONS
      cntl_error              = 1
      file_open_dialog_failed = 2
      error_no_gui            = 3.
  CALL METHOD cl_gui_cfw=>flush
    EXCEPTIONS
      cntl_error        = 1
      cntl_system_error = 2.
  READ TABLE lc_table ASSIGNING INDEX 1.
  CHECK sy-subrc EQ 0.
  l_file = -filename.
  CONDENSE l_file.
  SELECT SINGLE relid objid
    FROM wwwdata
    INTO CORRESPONDING FIELDS OF objdata
    WHERE srtf2 = 0
      AND relid = 'MI'
      AND bjid = p_name.
  IF sy-subrc <> 0.
    CONCATENATE '模板文件:' p_name '不存在,请用TCODE:SMW0进行加载'
           INTO l_string.
    MESSAGE l_string TYPE 'E'.
    EXIT.
  ENDIF.
  IF  objdata-objid = space .
    CONCATENATE '模板文件:' p_name '不存在,请用TCODE:SMW0进行加载'
           INTO l_string.
    MESSAGE l_string TYPE 'E'.
    EXIT.
  ENDIF.
  CALL FUNCTION 'DOWNLOAD_WEB_OBJECT'
    EXPORTING
      key         = objdata
      destination = l_file
    IMPORTING
      rc          = rc.
  IF rc <> 0.
    WRITE : / '模板文件:' , obj_name, '下载失败,请与开发人员联系'.
  ELSE.
    MESSAGE '该模板下载成功!!' TYPE 'S'.
    STOP.
  ENDIF.
 
 
注:上面的代码不是哥我原创的,是项目中施实公司高手留下的,方便日后查找,我把它放在日志里面,如果那位原创的高手看到,可别告我侵权啊^_^。
 
 

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/23353800/viewspace-731662/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/23353800/viewspace-731662/

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
SAP系统文件上传下载可以通过SAP内置的函数模块 `GUI_UPLOAD` 和 `GUI_DOWNLOAD` 来实现。下面是一个SAP文件上传下载的示例: 文件上传: ``` REPORT z_upload_file. DATA: lv_file TYPE string VALUE 'C:\temp\test.txt', lt_data TYPE STANDARD TABLE OF soli WITH HEADER LINE. * 读取本地文件数据 CALL FUNCTION 'GUI_UPLOAD' EXPORTING filename = lv_file TABLES data_tab = lt_data EXCEPTIONS file_open_error = 1 file_read_error = 2 no_batch = 3 gui_refuse_filetransfer = 4 invalid_type = 5 no_authority = 6 unknown_error = 7 header_not_allowed = 8 separator_not_allowed = 9 filesize_not_allowed = 10 header_too_long = 11 dp_error_create = 12 dp_error_send = 13 dp_error_write = 14 unknown_dp_error = 15 access_denied = 16 dp_out_of_memory = 17 disk_full = 18 dp_timeout = 19 file_not_found = 20 dataprovider_exception = 21 control_flush_error = 22 OTHERS = 23. IF sy-subrc EQ 0. MESSAGE '文件上传成功' TYPE 'S'. ELSE. MESSAGE '文件上传失败' TYPE 'E'. ENDIF. ``` 文件下载: ``` REPORT z_download_file. DATA: lv_file TYPE string VALUE 'C:\temp\test.txt', lt_data TYPE STANDARD TABLE OF soli WITH HEADER LINE. * 读取服务器文件数据 CALL FUNCTION 'GUI_DOWNLOAD' EXPORTING filename = lv_file TABLES data_tab = lt_data 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 EQ 0. MESSAGE '文件下载成功' TYPE 'S'. ELSE. MESSAGE '文件下载失败' TYPE 'E'. ENDIF. ``` 请根据实际需要,修改文件路径和文件名等参数。同时,需要注意的是,这种方式只适用于小文件上传下载。对于大文件,需要采用其他的方式,例如使用SAP数据传输工具(SAP Data Transfer Workbench)或者FTP等方式。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值