Chinaunix首页 | 论坛 | 博客
  • 博客访问: 463706
  • 博文数量: 199
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1902
  • 用 户 组: 普通用户
  • 注册时间: 2020-05-14 13:25
个人简介

代码5S

文章分类

全部博文(199)

文章存档

2021年(5)

2020年(194)

我的朋友

分类: 其他平台

2020-05-18 14:07:32

FUNCTION ZALSM_EXCEL_TO_INTERNAL_TABLE2 .
*"----------------------------------------------------------------------
*"*"本地接口:
*"  IMPORTING
*"     VALUE(FILENAME) LIKE  RLGRAP-FILENAME
*"     VALUE(I_BEGIN_COL) TYPE  I
*"     VALUE(I_BEGIN_ROW) TYPE  I
*"     VALUE(I_END_COL) TYPE  I
*"     VALUE(I_END_ROW) TYPE  I
*"     VALUE(SHEET_NAME) TYPE  CHAR50 OPTIONAL
*"  TABLES
*"      INTERN STRUCTURE  ZALSMEX_TABLINE2
*"  EXCEPTIONS
*"      INCONSISTENT_PARAMETERS
*"      UPLOAD_OLE
*"----------------------------------------------------------------------

  DATAexcel_tab     TYPE  ty_t_sender.
  DATAld_separator  TYPE  c.
  DATAapplication TYPE  ole2_object,
        workbook    TYPE  ole2_object,
        range       TYPE  ole2_object,
        worksheet   TYPE  ole2_object.
  DATAh_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 OTHERSRAISE upload_ole.
    ENDCASE.
  END-OF-DEFINITION.


* check parameters
  IF i_begin_row > i_end_rowRAISE inconsistent_parametersENDIF.
  IF i_begin_col > i_end_colRAISE inconsistent_parametersENDIF.

* 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.
*--ADD
**  set property of application 'Visible' = 1.
**  m_message.
  IF sheet_name space."用默认模式
    GET PROPERTY OF  application 'ACTIVESHEET' worksheet.
    m_message.
  ELSE.
*-->可以实现读取多个sheet
    CALL METHOD OF application 'WORKSHEETS' worksheet
      EXPORTING
        #1 sheet_name.

    CALL METHOD OF worksheet 'Activate'.
    m_message.
  ENDIF.
*---END OF------------------------------------------------

* 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_convert2 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.
阅读(1187) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~