sap文件上传与下载

FORM frm_file_download  USING  pv_sy_repid pv_filename pv_filter.
* pv_sy_repid = sy_repid
* pv_filename = xxx
* pv_filter = Excel文件 (*.XLSX)|*.XLSX|Excel文件 (*.XLS)|*.XLS
  DATA: lv_filename TYPE string.
  DATA: lv_filter   TYPE string.

  DATA: lv_obj_name    TYPE wwwdatatab-objid.
  DATA: lt_objdata     TYPE wwwdatatab.
  DATA: lv_destination TYPE localfile.

  DATA: lv_subrc    TYPE sy-subrc.
  DATA: lv_str      TYPE string.
  DATA: lv_path     TYPE string.
  DATA: lv_fullpath TYPE string.
  DATA: lv_wtitle   TYPE string.

  lv_obj_name = pv_sy_repid.
  lv_filename = pv_filename.
  lv_filter   = pv_filter.

  SELECT SINGLE relid objid
    FROM wwwdata
    INTO CORRESPONDING FIELDS OF lt_objdata
    WHERE srtf2 = 0
      AND relid = 'MI'
      AND objid = lv_obj_name.
  IF sy-subrc <> 0.
*    请检查文件是否正确
    MESSAGE TEXT-023 TYPE 'S' DISPLAY LIKE 'W'.
    EXIT.
  ENDIF.

  IF lv_filename IS INITIAL.
    SELECT SINGLE value INTO lv_filename
      FROM wwwparams
     WHERE relid = 'MI'
       AND objid = lv_obj_name
       AND name = 'filename'.
  ENDIF.
*  文件下载
  lv_wtitle = TEXT-018.
  CALL METHOD cl_gui_frontend_services=>file_save_dialog
    EXPORTING
      window_title         = lv_wtitle
      default_extension    = lv_filter
      default_file_name    = lv_filename
      file_filter          = lv_filter
    CHANGING
      filename             = lv_filename
      path                 = lv_path
      fullpath             = lv_fullpath .

  CHECK lv_fullpath IS NOT INITIAL.

  lv_destination = lv_fullpath.

  CALL FUNCTION 'DOWNLOAD_WEB_OBJECT'
    EXPORTING
      key         = lt_objdata
      destination = lv_destination
    IMPORTING
      rc          = lv_subrc.

  IF lv_subrc <> 0.
*    文件下载失败
    MESSAGE TEXT-019 TYPE 'S' DISPLAY LIKE 'E'.
    EXIT.
  ELSE.
*    文件下载成功
    MESSAGE TEXT-020 TYPE 'S'.
  ENDIF.
ENDFORM.
 
FORM frm_upload_data .

  DATA: lv_file TYPE string.
  DATA: lf_file_exists TYPE c.

  CALL FUNCTION 'SAPGUI_PROGRESS_INDICATOR'
    EXPORTING
*      正在处理,请等待...
      text = TEXT-021.

* 检查文件是否存在
  lv_file = p_file.
  CALL METHOD cl_gui_frontend_services=>file_exist
    EXPORTING
      file                 = lv_file
    RECEIVING
      result               = lf_file_exists
    EXCEPTIONS
      cntl_error           = 1
      error_no_gui         = 2
      wrong_parameter      = 3
      not_supported_by_gui = 4
    OTHERS                 = 5.


  IF sy-subrc = 0 AND lf_file_exists IS INITIAL.
*  上载数据为空,请检查!
    MESSAGE TEXT-022 TYPE 'S' DISPLAY LIKE 'E'.
    LEAVE LIST-PROCESSING.
  ENDIF.

* 上传文件 明细数据读取
  DATA: lt_excel TYPE TABLE OF alsmex_tabline .
*   读取本地EXCEL文件数据
  CALL FUNCTION 'ALSM_EXCEL_TO_INTERNAL_TABLE'
    EXPORTING
      filename                = p_file
      i_begin_col             = 1
      i_begin_row             = 3
      i_end_col               = 6
      i_end_row               = 100
    TABLES
      intern                  = lt_excel.

  IF lt_excel[] IS INITIAL.
*    上载数据为空,请检查!
    MESSAGE TEXT-022 TYPE 'S' DISPLAY LIKE 'E'.
    EXIT.
  ENDIF.

* 数据处理
  LOOP AT lt_excel INTO DATA(ls_excel).
    AT NEW row.
      APPEND INITIAL LINE TO gt_upload ASSIGNING FIELD-SYMBOL(<fsl_excel>).
    ENDAT.
    ASSIGN COMPONENT ls_excel-col OF STRUCTURE <fsl_excel> TO FIELD-SYMBOL(<fsl_data>).
    IF sy-subrc = 0.
      <fsl_data> =  ls_excel-value .
    ENDIF.
  ENDLOOP.
ENDFORM.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
水资源是人类社会的宝贵财富,在生活、工农业生产中是不可缺少的。随着世界人口的增长及工农业生产的发展,需水量也在日益增长,水已经变得比以往任何时候都要珍贵。但是,由于人类的生产和生活,导致水体的污染,水质恶化,使有限的水资源更加紧张。长期以来,油类物质(石油类物质和动植物油)一直是水和土壤中的重要污染源。它不仅对人的身体健康带来极大危害,而且使水质恶化,严重破坏水体生态平衡。因此各国都加强了油类物质对水体和土壤的污染的治理。对于水中油含量的检测,我国处于落后阶段,与国际先进水平存在差距,所以难以满足当今技术水平的要求。为了取得具有代表性的正确数据,使分析数据具有与现代测试技术水平相应的准确性和先进性,不断提高分析成果的可比性和应用效果,检测的方法和仪器是非常重要的。只有保证了这两方面才能保证快速和准确地测量出水中油类污染物含量,以达到保护和治理水污染的目的。开展水中油污染检测方法、技术和检测设备的研究,是提高水污染检测的一条重要措施。通过本课题的研究,探索出一套适合我国国情的水质污染现场检测技术和检测设备,具有广泛的应用前景和科学研究价值。 本课题针对我国水体的油污染,探索一套检测油污染的可行方案和方法,利用非分散红外光度法技术,开发研制具有自主知识产权的适合国情的适于野外便携式的测油仪。利用此仪器,可以检测出被测水样中亚甲基、甲基物质和动植物油脂的污染物含量,为我国众多的环境检测站点监测水体的油污染状况提供依据。
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等方式。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值