热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

SAP将内表的数据导出到本地xls文件abap实例INCLUDEOLE2INCL

目的:将abap中内表的数据导出到本地(local)的xls文件中。常用的方法有GUI_DOWNLOAD,但是该函数下载的是一些无转换文档,特别是TXT文件的导出。如果要实现e

目的:将abap中内表的数据导出到本地(local)的xls文件中。

常用的方法有GUI_DOWNLOAD,但是该函数下载的是一些无转换文档,特别是TXT文件的导出。

如果要实现excel文件,并且把字段按照不同列进行输出,需要使用到object:OLE2_OBJECT来实现。

 

一个实例如下:

INCLUDE OLE2INCL

 

* ALV呼出
  CALL FUNCTION ‘REUSE_ALV_GRID_DISPLAY‘
    EXPORTING
      I_CALLBACK_PROGRAM          SY-REPID
      I_CALLBACK_PF_STATUS_SET    ‘PF_STATUS_SET‘
      I_CALLBACK_USER_COMMAND     ‘PF_USER_COMMAND‘
*     i_callback_html_top_of_page = ‘TOP_OF_PAGE‘
      IS_LAYOUT                   PS_IN_LAYOUT
      IT_FIELDCAT                 PT_IN_FIELDCAT
      I_SAVE                      ‘X‘
    TABLES
      T_OUTTAB                    GT_ALVDATA
    EXCEPTIONS
      PROGRAM_ERROR               1
      OTHERS                      2.
  IF SY-SUBRC <> 0.
*   Implement suitable error handling here
    MESSAGE ID SY-MSGID TYPE ‘S‘ NUMBER SY-MSGNO DISPLAY LIKE ‘E‘
                                   WITH SY-MSGV1
                                        SY-MSGV2
                                        SY-MSGV3
                                        SY-MSGV4.
    LEAVE LIST-PROCESSING.
  ENDIF.

 

ALV自定义按钮处理

*&---------------------------------------------------------------------*
*&      Form  PF_USER_COMMAND
*&---------------------------------------------------------------------*
*       USER_COMMAND
*----------------------------------------------------------------------*
*      -->P_UCOMM      text
*      -->PS_SELFIELD  text
*----------------------------------------------------------------------*
FORM PF_USER_COMMAND USING P_UCOMM     LIKE SY-UCOMM
                           PS_SELFIELD TYPE SLIS_SELFIELD.
  CASE P_UCOMM.
    WHEN ‘DOWN‘.
*     下载数据到xls文件
      PERFORM FRM_DOWNLOAD_DATA.
    WHEN OTHERS.
  ENDCASE.
  PS_SELFIELD-REFRESH ‘X‘.
ENDFORM.                    "PF_USER_COMMAND

 

*&---------------------------------------------------------------------*
*&      Form  FRM_DOWNLOAD_DATA
*&---------------------------------------------------------------------*
*       下载数据到xls文件
*----------------------------------------------------------------------*
FORM FRM_DOWNLOAD_DATA .
  DATALV_EXCEL       TYPE OLE2_OBJECT,
        LV_SHEET       TYPE OLE2_OBJECT,
        LV_CELL        TYPE OLE2_OBJECT,
        LV_WORKBOOK    TYPE OLE2_OBJECT,
        LV_XLSNAME     TYPE STRING,
        LV_LINE        TYPE I      VALUE 1"行号
        LV_COLS        TYPE I      VALUE 0"行号
        LW_ALVDATA     TYPE GTYP_ALVDATA.
* 获取下载文件完整路径
  PERFORM GET_SAVE_PATH CHANGING LV_XLSNAME.
* 启动Excel
  CREATE OBJECT LV_EXCEL ‘EXCEL.APPLICATION‘.
  IF SY-SUBRC <> 0.
    WRITE‘启动Excel失败。‘.
    STOP.
  ENDIF.
  CALL METHOD OF
      LV_EXCEL
      ‘WORKBOOKS‘ LV_WORKBOOK.
* 使excel 可视
  SET PROPERTY OF LV_EXCEL ‘VISIBLE‘             0. "0:不可视,1:可视
  SET PROPERTY OF LV_EXCEL ‘SHEETSINNEWWORKBOOK‘ 1.
  "如果是读取excel文件中的内容 则是直接打开工作簿第一页
  CALL METHOD OF
      LV_WORKBOOK
      ‘ADD‘.
* 例如:CALL
*       METHOD OF EXCEL ‘WORKSHEETS‘  = SHEET  EXPORTING #1 = 1.
*  CLEAR LV_LINE.
  LOOP AT GT_ALVDATA INTO LW_ALVDATA.
    LV_COLS 1.
*   列名的设定
    IF SY-TABIX 1.
*     设定单元&#26684;(交货)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘交货‘
                                   LV_COLS.
*     设定单元&#26684;(物料号)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘物料号‘
                                   LV_COLS.
*     设定单元&#26684;(交货日期)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘交货日期‘
                                   LV_COLS.
*     设定单元&#26684;(实际已交货量(按销售单位))
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘实际已交货量(按销售单位)‘
                                   LV_COLS.
*     设定单元&#26684;-列(售达方)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘售达方‘
                                   LV_COLS.
*     设定单元&#26684;-列(工厂)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘工厂‘
                                   LV_COLS.
*     设定单元&#26684;-列(销售单价(SA中的单价))
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘销售单价(SA中的单价)‘
                                   LV_COLS.
*     设定单元&#26684;-列(销售金额)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘销售金额‘
                                   LV_COLS.
*     设定单元&#26684;-列(标准价&#26684;)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘标准价&#26684;‘
                                   LV_COLS.
*     设定单元&#26684;-列(标准成本总额)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘标准成本总额‘
                                   LV_COLS.
*     设定单元&#26684;-列(天数)
      PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                   LV_LINE
                                   ‘天数‘
                                   LV_COLS.
    ENDIF.
    LV_LINE LV_LINE &#43; 1.   "Excel 中行号从1开始
    LV_COLS 1.
*   设定单元&#26684;(交货)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-VBELN
                                 LV_COLS.
*   设定单元&#26684;(物料号)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-MATNR
                                 LV_COLS.
*   设定单元&#26684;(交货日期)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-LFDAT
                                 LV_COLS.
*   设定单元&#26684;(实际已交货量(按销售单位))
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-LFIMG
                                 LV_COLS.
*   设定单元&#26684;-列(售达方)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-KUNAG
                                 LV_COLS.
*   设定单元&#26684;-列(工厂)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-WERKS
                                 LV_COLS.
*   设定单元&#26684;-列(销售单价(SA中的单价))
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-KBETR
                                 LV_COLS.
*   设定单元&#26684;-列(销售金额)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-SAL_AMOUNT
                                 LV_COLS.
*   设定单元&#26684;-列(标准价&#26684;)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-STPRS
                                 LV_COLS.
*   设定单元&#26684;-列(标准成本总额)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-SUM_AMOUNT
                                 LV_COLS.
*   设定单元&#26684;-列(天数)
    PERFORM SET_EXCEL_CELL USING LV_EXCEL
                                 LV_LINE
                                 LW_ALVDATA-ATAGE
                                 LV_COLS.
  ENDLOOP.
  GET PROPERTY OF LV_EXCEL ‘ACTIVESHEET‘    LV_SHEET.     "激活工作簿
  GET PROPERTY OF LV_EXCEL ‘ACTIVEWORKBOOK‘ LV_WORKBOOK.  "激活工作区
  CALL METHOD OF
      LV_WORKBOOK
      ‘SAVEAS‘
    EXPORTING
      #1          LV_XLSNAME
      #2          1.
  "将excel文件保存
  CALL METHOD  OF LV_WORKBOOK ‘CLOSE‘.                  "关闭工作区
  CALL METHOD OF
      LV_EXCEL
      ‘QUIT‘.
  "退出excel
*WRITE:/ XLSNAME,‘DONE‘.
  "退出成功,输出done
  FREE OBJECT LV_SHEET.                               "释放操作
  FREE OBJECT LV_WORKBOOK.
  FREE OBJECT LV_EXCEL.
ENDFORM.                    " FRM_DOWNLOAD_DATA
*&---------------------------------------------------------------------*
*&      Form  SET_EXCEL_CELL
*&---------------------------------------------------------------------*
*       设定单元&#26684;-列
*----------------------------------------------------------------------*
*      -->P_IN_EXCEL     excel对象
*      -->P_IN_LINE      行号
*      -->P_IN_FIELD     项目
*      <--P_OUT_COLS     列号
*----------------------------------------------------------------------*
FORM SET_EXCEL_CELL  USING  P_IN_EXCEL  TYPE OLE2_OBJECT
                            P_IN_LINE   TYPE I
                            P_IN_FIELD  TYPE ANY
                            P_OUT_COLS  TYPE I.
  DATALV_CELL   TYPE OLE2_OBJECT.
* 指定单元&#26684;
  CALL METHOD OF
      P_IN_EXCEL
      ‘CELLS‘    LV_CELL
    EXPORTING
      #1         P_IN_LINE
      #2         P_OUT_COLS.
* 写入&#20540;
  SET  PROPERTY OF LV_CELL
                   ‘VALUE‘ P_IN_FIELD.
  P_OUT_COLS P_OUT_COLS &#43; 1.
ENDFORM.                    " SET_EXCEL_CELL
*&---------------------------------------------------------------------*
*&      Form  GET_SAVE_PATH
*&---------------------------------------------------------------------*
*       获取下载文件完整路径
*----------------------------------------------------------------------*
*      <--P_IN_PATH  text
*----------------------------------------------------------------------*
FORM GET_SAVE_PATH  CHANGING P_IN_PATH  TYPE STRING.
  DATALV_FILENAME   TYPE STRING,
        LV_PATH       TYPE STRING.
  CALL METHOD CL_GUI_FRONTEND_SERVICES=>FILE_SAVE_DIALOG
    EXPORTING
      WINDOW_TITLE         ‘下载文件‘
      FILE_FILTER          ‘*.xls‘
    CHANGING
      FILENAME             LV_FILENAME
      PATH                 LV_PATH
      FULLPATH             P_IN_PATH
    EXCEPTIONS
      CNTL_ERROR           1
      ERROR_NO_GUI         2
      NOT_SUPPORTED_BY_GUI 3
      OTHERS               4.
  IF SY-SUBRC <> 0.
*   Implement suitable error handling here
  ENDIF.
ENDFORM.                    " GET_SAVE_PATH

 

效果图如下:

bubuko.com,布布扣

 

bubuko.com,布布扣

 

bubuko.com,布布扣

 

 

 

 

 

 

 

 

SAP 将内表的数据导出到本地xls文件 abap实例 INCLUDE OLE2INCL,布布扣,bubuko.com


推荐阅读
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文内容为asp.net微信公众平台开发的目录汇总,包括数据库设计、多层架构框架搭建和入口实现、微信消息封装及反射赋值、关注事件、用户记录、回复文本消息、图文消息、服务搭建(接入)、自定义菜单等。同时提供了示例代码和相关的后台管理功能。内容涵盖了多个方面,适合综合运用。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 后台获取视图对应的字符串
    1.帮助类后台获取视图对应的字符串publicclassViewHelper{将View输出为字符串(注:不会执行对应的ac ... [详细]
  • 《数据结构》学习笔记3——串匹配算法性能评估
    本文主要讨论串匹配算法的性能评估,包括模式匹配、字符种类数量、算法复杂度等内容。通过借助C++中的头文件和库,可以实现对串的匹配操作。其中蛮力算法的复杂度为O(m*n),通过随机取出长度为m的子串作为模式P,在文本T中进行匹配,统计平均复杂度。对于成功和失败的匹配分别进行测试,分析其平均复杂度。详情请参考相关学习资源。 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • 动态规划算法的基本步骤及最长递增子序列问题详解
    本文详细介绍了动态规划算法的基本步骤,包括划分阶段、选择状态、决策和状态转移方程,并以最长递增子序列问题为例进行了详细解析。动态规划算法的有效性依赖于问题本身所具有的最优子结构性质和子问题重叠性质。通过将子问题的解保存在一个表中,在以后尽可能多地利用这些子问题的解,从而提高算法的效率。 ... [详细]
  • 本文介绍了指针的概念以及在函数调用时使用指针作为参数的情况。指针存放的是变量的地址,通过指针可以修改指针所指的变量的值。然而,如果想要修改指针的指向,就需要使用指针的引用。文章还通过一个简单的示例代码解释了指针的引用的使用方法,并思考了在修改指针的指向后,取指针的输出结果。 ... [详细]
  • 在project.properties添加#Projecttarget.targetandroid-19android.library.reference.1..Sliding ... [详细]
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
author-avatar
rgx-秀_550
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有