ABAP EXCEL导入与导出(一)

该文章详细记录了在SAPABAP环境中如何实现Excel的导入和导出功能。首先,通过GUI服务下载系统模板到本地,然后使用ALSM_EXCEL_TO_INTERNAL_TABLE函数将Excel数据读取到内部表,最后对数据进行校验和处理,准备进一步的业务操作。
摘要由CSDN通过智能技术生成

需求场景:

导入和导出EXCEL是日常一个比较常见的需求,本篇博客记录一下EXCEL导入的功能,下一篇会记录EXCEL导出。

1.下载系统模板

PERFORM frm_downexceltemplete USING '国内报价单模板' 'ZMMC001R2'.
FORM frm_downexceltemplete USING p_default p_objid.
  DATA: l_filepath TYPE string,
        l_filename TYPE string,
        l_path     TYPE string,
        l_default  TYPE string,
        lv_title   TYPE string.

  DATA: l_subrc TYPE sy-subrc.
  DATA: w_excel_filename TYPE string,
        w_objid          LIKE wwwdatatab-objid,
        wa_objdata       LIKE wwwdatatab,
        w_dest           LIKE rlgrap-filename.

  CLEAR: w_objid,w_excel_filename.

  MOVE: p_default TO  l_default,
        p_objid TO w_objid.

  lv_title = text-007.

  CALL METHOD cl_gui_frontend_services=>file_save_dialog
    EXPORTING
      window_title         = lv_title
      default_file_name    = l_default
      file_filter          = '.XLS'
      initial_directory    = 'C:\TEMP'
      prompt_on_overwrite  = 'X'
    CHANGING
      filename             = l_filename
      path                 = l_path
      fullpath             = l_filepath
    EXCEPTIONS
      cntl_error           = 1
      error_no_gui         = 2
      not_supported_by_gui = 3
      OTHERS               = 4.
  IF sy-subrc <> 0.
    MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
    WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
  ENDIF.

  IF l_filename IS NOT INITIAL AND l_filename NS '.XLS'.
    CONCATENATE l_filename '.XLSX' INTO l_filename.
  ENDIF.

* 服务器下载模板表
  IF NOT l_filepath IS INITIAL.

    MOVE: l_filename TO w_excel_filename.


    SELECT SINGLE relid
    objid
    FROM wwwdata
    INTO CORRESPONDING FIELDS OF wa_objdata
    WHERE srtf2 = 0
    AND relid = 'MI'
    AND objid = w_objid.

    IF sy-subrc NE 0.
      MESSAGE e398(00) WITH text-008.
    ENDIF.

* 下载模板文件
    w_dest =  w_excel_filename.

    CALL FUNCTION 'DOWNLOAD_WEB_OBJECT'
      EXPORTING
        key         = wa_objdata
        destination = w_dest
      IMPORTING
        rc          = l_subrc.

    IF l_subrc NE 0.
      MESSAGE e398(00) WITH text-009.
    ENDIF.
  ENDIF.
ENDFORM.                    " FRM_DOWNEXCELTEMPLETE

2.读取数据到内部表

FORM frm_upload_data01 USING p_colums.
  DATA:lv_kunnr TYPE kunnr,
       lv_werks TYPE werks_d,
       lv_bjh   LIKE zmmt036-zbjh,
       lv_bukrs TYPE bukrs.

  DATA:len  TYPE int4,
       len1 TYPE int4.

  DATA:lv_zwzc(2).

  DATA:lv_type TYPE dd01v-datatype.

  DATA:lv_num      TYPE i,lv_num_char.
  CLEAR:lv_num.
  REFRESH: gt_excel.

  gv_pfname = p_file.
  CONDENSE gv_pfname.

  CALL FUNCTION 'ALSM_EXCEL_TO_INTERNAL_TABLE'
    EXPORTING
      filename                = gv_pfname
      i_begin_col             = 1
      i_begin_row             = 1
      i_end_col               = p_colums
      i_end_row               = 99999
    TABLES
      intern                  = gt_excel
    EXCEPTIONS
      inconsistent_parameters = 1
      upload_ole              = 2
      OTHERS                  = 3.
  IF sy-subrc <> 0.
    WRITE: / text-028,gv_pfname.
    EXIT.
  ELSE.
    LOOP AT gt_excel.
      CONDENSE gt_excel-value.
      MODIFY gt_excel.
    ENDLOOP.
  ENDIF.

  CLEAR:lv_kunnr,lv_bjh,lv_werks,lv_bukrs.
  lv_num = 1.
  LOOP AT gt_excel.
    CASE gt_excel-row.
      WHEN '0001'.
      WHEN '0002'.
        CASE gt_excel-col.
          WHEN '0003'.
          WHEN '0009'.
        ENDCASE.
      WHEN '0003'.
      WHEN '0004'.
      WHEN OTHERS.
        CASE gt_excel-col.
          WHEN '0001'.
          WHEN '0002'.
          WHEN '0003'.
          WHEN '0004'.
          WHEN '0005'.
          WHEN '0006'.
          WHEN '0008'.
          WHEN '0009'.
          WHEN OTHERS.
        ENDCASE.
        AT END OF row."判断读到行数据的最后一列数据
          gs_output01-zbjh = lv_bjh.
          gs_output01-zvendor = lv_kunnr.
          gs_output01-zwerks = lv_werks.
          gs_output01-bukrs = lv_bukrs.
          APPEND gs_output01 TO gt_output01.
          CLEAR:gs_output01.
        ENDAT.
    ENDCASE.
  ENDLOOP.
ENDFORM.                    " FRM_UPLOAD_DATA01

3.数据校验和处理

通过第二步把数据已经读取到内表了,下一步可以对数据进行校验,校验后的数据就可以根据业务需求进行后续处理了。

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
ABAP可以使用函数模块GUI_DOWNLOAD和ALSM_EXCEL_TO_INTERNAL_TABLE来动态导出Excel表。 首先,使用ALSM_EXCEL_TO_INTERNAL_TABLE函数将数据导入到内部表中。以下是一个简单的例子: ``` DATA: it_data TYPE STANDARD TABLE OF mara, wa_data TYPE mara. SELECT * FROM mara INTO TABLE it_data. CALL FUNCTION 'ALSM_EXCEL_TO_INTERNAL_TABLE' EXPORTING filename = 'example.xlsx' i_begin_col = 'A' i_begin_row = 1 i_end_col = 'D' i_end_row = 1000 TABLES intern = it_data EXCEPTIONS inconsistent_parameters = 1 upload_ole = 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. ``` 然后,使用函数模块GUI_DOWNLOAD将内部表中的数据导出Excel文件中。以下是一个简单的例子: ``` DATA: it_data TYPE STANDARD TABLE OF mara, wa_data TYPE mara. SELECT * FROM mara INTO TABLE it_data. CALL FUNCTION 'ALSM_EXCEL_TO_INTERNAL_TABLE' EXPORTING filename = 'example.xlsx' i_begin_col = 'A' i_begin_row = 1 i_end_col = 'D' i_end_row = 1000 TABLES intern = it_data EXCEPTIONS inconsistent_parameters = 1 upload_ole = 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. CALL FUNCTION 'GUI_DOWNLOAD' EXPORTING filename = 'example.xlsx' filetype = 'ASC' write_field_separator = ' ' TABLES data_tab = it_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 <> 0. MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. ENDIF. ``` 在这些例子中,使用了内部表mara来存储数据,将数据导入Excel文件中。你可以根据需要更改内部表和字段名称。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值