SAP ABAP 导入excel表,导多个sheet

文章目录

注意事项

完整代码

SAPLZTEST_FGLHY01-主程序

js 复制代码
*******************************************************************
*   System-defined Include-files.                                 *
*******************************************************************
  INCLUDE LZTEST_FGLHY01TOP.                 " Global Declarations
  INCLUDE LZTEST_FGLHY01UXX.                 " Function Modules
  INCLUDE LALSMEXF01.                    " Function Modules

*******************************************************************
*   User-defined Include-files (if necessary).                    *
*******************************************************************
* INCLUDE LZTEST_FGLHY01F...                 " Subroutines
* INCLUDE LZTEST_FGLHY01O...                 " PBO-Modules
* INCLUDE LZTEST_FGLHY01I...                 " PAI-Modules
* INCLUDE LZTEST_FGLHY01E...                 " Events
* INCLUDE LZTEST_FGLHY01P...                 " Local class implement.
* INCLUDE LZTEST_FGLHY01T99.                 " ABAP Unit tests

LZTEST_FGLHY01TOP

js 复制代码
FUNCTION-POOL ZTEST_FGLHY01 MESSAGE-ID ME.                 "MESSAGE-ID ..

* INCLUDE LZTEST_FGLHY01D...                 " Local class definition

TYPE-POOLS: ole2.
TYPES: ty_d_itabvalue             TYPE zalsmex_tabline3-value,
       ty_t_itab                  TYPE zalsmex_tabline3   OCCURS 0,
       BEGIN OF ty_s_senderline,
         line(4096)               TYPE c,
       END OF ty_s_senderline,
       ty_t_sender                TYPE ty_s_senderline  OCCURS 0.
CONSTANTS:  gc_esc              VALUE '"'.

函数模块代码

js 复制代码
FUNCTION ZALSM_EXCEL_TO_INTERNAL_TABLE3 .
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     REFERENCE(FILENAME) LIKE  RLGRAP-FILENAME
*"     REFERENCE(I_BEGIN_COL) TYPE  I
*"     REFERENCE(I_BEGIN_ROW) TYPE  I
*"     REFERENCE(I_END_COL) TYPE  I
*"     REFERENCE(I_END_ROW) TYPE  I
*"     REFERENCE(I_WORKSHEET) TYPE  CHAR30 OPTIONAL
*"  TABLES
*"      INTERN STRUCTURE  ZALSMEX_TABLINE3
*"----------------------------------------------------------------------
  DATA: excel_tab     TYPE  ty_t_sender.
  DATA: ld_separator  TYPE  c.
  DATA: application TYPE  ole2_object,
        workbook    TYPE  ole2_object,
        range       TYPE  ole2_object,
        worksheet   TYPE  ole2_object.
  DATA: h_cell  TYPE  ole2_object,
        h_cell1 TYPE  ole2_object.
  DATA:
    ld_rc             TYPE i.
*   Rückgabewert der Methode "clipboard_export     "

* Makro für Fehlerbehandlung der Methods
  DEFINE m_message.
    CASE sy-subrc.
      WHEN 0.
      WHEN 1.
        MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno
                WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4.
      WHEN OTHERS. RAISE upload_ole.
    ENDCASE.
  END-OF-DEFINITION.


* check parameters
  IF i_begin_row > i_end_row. RAISE inconsistent_parameters. ENDIF.
  IF i_begin_col > i_end_col. RAISE inconsistent_parameters. ENDIF.

* Get TAB-sign for separation of fields
  CLASS cl_abap_char_utilities DEFINITION LOAD.
  ld_separator = cl_abap_char_utilities=>horizontal_tab.

* open file in Excel
  IF application-header = space OR application-handle = -1.
    CREATE OBJECT application 'Excel.Application'.
    m_message.
  ENDIF.
  CALL METHOD OF application 'Workbooks' = workbook.
  m_message.
  CALL METHOD OF workbook 'Open' EXPORTING #1 = filename.
  m_message.
*  set property of application 'Visible' = 1.
*  m_message.
  IF i_worksheet IS NOT INITIAL .

    CALL METHOD OF application 'Worksheets' = worksheet
    EXPORTING
      #1 = i_worksheet.

    CALL METHOD OF worksheet 'Activate '.

  ENDIF .
  GET PROPERTY OF  application 'ACTIVESHEET' = worksheet.
  m_message.

* mark whole spread sheet
  CALL METHOD OF worksheet 'Cells' = h_cell
      EXPORTING #1 = i_begin_row #2 = i_begin_col.
  m_message.
  CALL METHOD OF worksheet 'Cells' = h_cell1
      EXPORTING #1 = i_end_row #2 = i_end_col.
  m_message.

  CALL METHOD  OF worksheet 'RANGE' = range
                 EXPORTING #1 = h_cell #2 = h_cell1.
  m_message.
  CALL METHOD OF range 'SELECT'.
  m_message.

* copy marked area (whole spread sheet) into Clippboard
  CALL METHOD OF range 'COPY'.
  m_message.

* read clipboard into ABAP
  CALL METHOD cl_gui_frontend_services=>clipboard_import
    IMPORTING
      data       = excel_tab
    EXCEPTIONS
      cntl_error = 1
*     ERROR_NO_GUI         = 2
*     NOT_SUPPORTED_BY_GUI = 3
      OTHERS     = 4.
  IF sy-subrc <> 0.
    MESSAGE a037(alsmex).
  ENDIF.

  PERFORM separated_to_intern_convert TABLES excel_tab intern
                                      USING  ld_separator.

* clear clipboard
  REFRESH excel_tab.
  CALL METHOD cl_gui_frontend_services=>clipboard_export
    IMPORTING
      data       = excel_tab
    CHANGING
      rc         = ld_rc
    EXCEPTIONS
      cntl_error = 1
*     ERROR_NO_GUI         = 2
*     NOT_SUPPORTED_BY_GUI = 3
      OTHERS     = 4.

* quit Excel and free ABAP Object - unfortunately, this does not kill
* the Excel process
  CALL METHOD OF application 'QUIT'.
  m_message.

* >>>>> Begin of change note 575877
* to kill the Excel process it's necessary to free all used objects
  FREE OBJECT h_cell.       m_message.
  FREE OBJECT h_cell1.      m_message.
  FREE OBJECT range.        m_message.
  FREE OBJECT worksheet.    m_message.
  FREE OBJECT workbook.     m_message.
  FREE OBJECT application.  m_message.
* <<<<< End of change note 575877
ENDFUNCTION.

引入标准的INCLUDE LALSMEXF01.

相关推荐
appleคิดถึง4 小时前
tp6数据导出excel文件时对大数据量处理
php·excel·tp6
heartbeat..4 小时前
注解 + 反射:Web 项目 Excel 一键导出工具 EnhancedExportExcelUtil 详解
java·excel·poi
山茶花开时。10 小时前
[SAP ABAP] CONVERSION_EXIT_ALPHA_INPUT
sap·abap
yivifu11 小时前
Excel表格取多行数据中的唯一值及多条件数据查询问题
excel
天一生水water16 小时前
顶级多项目管理 Excel 模板
excel·敏捷流程
取啥都被占用16 小时前
VBA的excel逐行替换到word模板及打印还原
excel·vba
坚定信念,勇往无前18 小时前
vue3图片,pdf,word,excel,ppt多格式文件预览组件Vue Doc Viewers Plus
pdf·word·excel
weixin_462446231 天前
【原创实践】python 获取节假日列表 并保存为excel
数据库·python·excel
缺点内向2 天前
如何在C#中添加Excel文档属性?
开发语言·数据库·c#·.net·excel
shouchaobao2 天前
仓库房进销存Excel模板合集:商品采购+出入库+库存统计一站式管理,适配仓库管理员/中小企业/个体商户
excel