ABAP DOI详解(1)

2023-10-28

什么是 DOI?

DOI 是Desktop Office Integration的缩写,是 SAP 提供的解决与 Office 集成的技术方案。早期 SAP 用 OLE 技术解决 与 Office 集成。OLE 语法参照 VBA,在 ABAP 中调用方法来操作 Excel,语法的友好性差;另外将数据从ABAP 内表写入到 Excel ,速度特别慢,性能难以接受。

DOI 可以看作 OLE 的替代品,用面向对象的方式实现。很好的解决了上面所说的两个问题。(参考:Desktop Office Integration官方帮助

DOI 开发的技术要点

相关对象

SAP 与 Office 集成,既可以通过代码创建 Excel 文档,也可以将 Excel 模板文档放在应用程序服务器上由 DOI 调用,DOI 打开这个文档,对文档进行操作和处理。我们先介绍代码创建 Excel 文档的方式。为了操作 Excel 文档,至少需要四个对象:

  • container: 存放 Excel 电子表格 (spreadsheet) 的容器。这个应该比较容易理解,容器一般在 dialog screen 中定义,也可以直接使用 ABAP 程序中默认的 screen(即 screen 号码为 1000 的屏幕)

  • container control: 容器中用于创建和管理其他 Office 集成所需要的对象,container control 是一个接口,类型为 i_oi_container_control

  • document proxy: 每一个 document proxy 的实例代表用 office application 打开的文档,可以是 Excel,也可以是 Word,如果想打开多个文档,需要定义多个实例。document proxy 是一个接口,类型为 i_oi_document_proxy

  • spreadsheet: spreadsheet 接口,代表最终要操作的 Excel文档,spreadhseet 的类型是 i_oi_spreadsheet

  • business document set: 如果读取服务器上的文档模板,用 cl_bds_document_set 类,将business document set缩写为 bds,bds 用于管理要操作的文档,可以包含一个或多个文档。

DOI 操作 Excel 的步骤

  • 获取 container
  • 创建 container control 对象实例
  • 创建 document proxy 对象的实例
  • 打开一个服务器上的模板文档或新建一个新的 Excel 文档
  • 操作打开的 Excel 文档,设置 Excel 相关属性或调用相关方法
  • 退出时关闭 Excel 文档,释放资源

我们的第一个例子,不使用 dialog screen,新建一个 Excel 文档,在屏幕 1000 中显示。以下是开发步骤:

定义公共变量

* desktop office integration interface
data: gr_container type ref to cl_gui_container,
      gr_control type ref to i_oi_container_control,
      gr_document type ref to i_oi_document_proxy,
      gr_spreadsheet type ref to i_oi_spreadsheet.

这些就是我们前面提到的四个必须的对象。

获取container

cl_gui_container 类的静态方法 screen0 获取屏幕 1000,并赋值给 gr_container。

form get_container.
  gr_container = cl_gui_container=>screen0.
endform.  

创建 container control 对象实例并初始化

代码比较直观,不多解释。

form create_container_control.
* create container control
  call method c_oi_container_control_creator=>get_container_control
    importing
      control = gr_control.

* initialize control
  call method gr_control->init_control
    exporting
      inplace_enabled          = 'X '
      inplace_scroll_documents = 'X'
      register_on_close_event  = 'X'
      register_on_custom_event = 'X'
      r3_application_name      = 'DOI demo by Stone Wang'
      parent                   = gr_container.
endform.   

创建 document proxy 对象的实例

form create_excel_document.
  call method gr_control->get_document_proxy
    exporting
      document_type  = 'Excel.Sheet'
      no_flush       = 'X'
    importing
      document_proxy = gr_document.

  call method gr_document->create_document
    exporting
      document_title = 'DOI test by Stone Wang '
      no_flush       = 'X '
      open_inplace   = 'X'.
endform.                    "create_excel_document

open_inplace 参数控制 Excel 文档是独立显示还是在 SAP GUI 中嵌入显示。如果嵌入式显示,gr_controlinit_control 方法中,inplace_enabled 参数要设为 X

将以上代码综合在一起:

form main.
  skip 1.

  perform get_container.
  perform create_container_control.
  perform create_excel_document.
endform.

注意第一句 skip 1 必须,否则不能创建屏幕。

完整代码

report  zdoi_hello.

type-pools: soi.

data: gr_container type ref to cl_gui_container,
      gr_control type ref to i_oi_container_control,
      gr_document type ref to i_oi_document_proxy,
      gr_spreadsheet type ref to i_oi_spreadsheet.

start-of-selection.
  perform main.

form get_container.
  gr_container = gr_container = cl_gui_container=>screen0.
endform.                    "get_container

form create_container_control.
* create container control
  call method c_oi_container_control_creator=>get_container_control
    importing
      control = gr_control.

* initialize control
  call method gr_control->init_control
    exporting
      inplace_enabled          = 'X '
      inplace_scroll_documents = 'X'
      register_on_close_event  = 'X'
      register_on_custom_event = 'X'
      r3_application_name      = 'DOI demo by Stone Wang'
      parent                   = gr_container.
endform.                    "create_container_control

form create_excel_document.
  call method gr_control->get_document_proxy
    exporting
      document_type  = 'Excel.Sheet'
      no_flush       = 'X'
    importing
      document_proxy = gr_document.

  call method gr_document->create_document
    exporting
      document_title = 'DOI test by Stone Wang '
      no_flush       = 'X '
      open_inplace   = 'X'.
endform.                    "create_excel_document

form main.
  skip 1.

  perform get_container.
  perform create_container_control.
  perform create_excel_document.
endform.

操作 Excel 文档以及获取模板文档放在下一节,以降低学习和理解的难度。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

ABAP DOI详解(1) 的相关文章

  • 第二章 数据迁移之Dolphinscheduler调度DataX从Mysql全量导入Hive

    绪 需求说明 将源系统mysql表数据全量抽取到hive中作为ODS层 不保留历史变化 create table T YYBZB TGH BANKINFO id int 8 bank id int 8 bank name varchar 2
  • 第四届蓝桥杯Java B组 马虎的算式

    马虎的算式 Description 小明是个急性子 上小学的时候经常把老师写在黑板上的题目抄错了 有一次 老师出的题目是 36 x 495 他却给抄成了 396 x 45 但结果却很戏剧性 他的答案竟然是对的 因为 36 x 495 396
  • unity航点寻径

    一 游戏框架 设置了六个路标 角色会在这六个路标之间一次移动 当移动到第六个路标后又会返回第一个路标 继续依次移动 road 道路 由五个立方体组成 sign 路标 由六个胶囊组成 enemy 寻路的角色 二 游戏实现 1 创建一个平面 赋
  • RGB颜色对照表大全

    常用颜色rgb 颜色对照表 一 R G B 值 R G B 值 R G B 值 黑色 0 0 0 000000 黄色 255 255 0 FFFF00 浅灰蓝色 176 224 230 B0E0E6 象牙黑 41 36 33 292421
  • pdf预览

    previewSop url axios get url responseType arraybuffer then res gt var data res data var blob new Blob data type applicat
  • 实现多线程爬取数据并保存到mongodb

    多线程爬取二手房网页并将数据保存到mongodb的代码 import pymongo import threading import time from lxml import etree import requests from queu
  • 什么是3d虚拟数字人?对未来发展有什么影响?

    3d虚拟数字人指的是以数字形式存在的人工智能 也被称为数字智能体 无论是在我们的周围 还是我们自己的体内 他们都能够利用数据和代码来进行模拟 操纵和创造各种不同的人类形态 基本上来说 数字人就是指那些具备大脑 眼睛 手和嘴等特性的数字化机器
  • 【Analyzing and Mitigating Interference in Neural Architecture Search】分析与缓解NAS权重共享方法中的子模型之间的干扰问题

    Analyzing and Mitigating Interference in Neural Architecture Search 论文地址 https proceedings mlr press v162 xu22h html 摘要
  • google-app-engine 上传下载 用户文件

    http blog notdot net 2009 9 Handling file uploads in App Engine http hi baidu com zjm1126 item 31d65e31962da022b3c0c56e
  • 数据库中如何将数据库文件转移到其他主机中

    目录 一 数据库文件 二 方法一 分离 gt 附加 三 方法二 脱机 gt 附加
  • VS问题总结记录(持续更新)

    1 error MSB8020 无法找到 v142 的生成工具 平台工具集 v142 若要使用 v142 生成工具进行生成 请安装 v142 生成工具 https blog csdn net weixin 39956356 article
  • 丰田工机安全plc编程软件pcwin safe

    丰田工机安全plc编程软件pcwin safe 14而且还是中文版的 绝对是难得的资源 toyopuc YID 17200678135439768 在现代工业领域 计算机技术的广泛应用已成为了工厂生产和管理的重要组成部分 同时也给工业安全带
  • node.js 如何读取json文件内容

    最简单的方式 const config require config json console log name config name console log age config age require方法的缺点 内容会被缓存 不适合动
  • cocos2d-x 浅析斗地主游戏分牌动作

    cocos2d x 浅析斗地主游戏分牌动作 分类 C C Cocos2d x学习笔记 2013 05 17 13 54 461人阅读 评论 0 收藏 举报 cocos2d x 斗地主 动作 最近在开发一款基于cocos2d x的斗地主棋牌游
  • MATLA技巧

    如何将MATLAB矩阵每列都归一化为单位向量 function matrix normalized norm matrix by column matrix column norms sqrt sum abs matrix 2 1 or v
  • 10款最著名的代码(文本)编辑器

    通常操作系统和软件开发包中都包含文本编辑器 可以用来编辑配置文件 文档文件和源代码 下面是笔者总结的 10 个最好的免费代码文本编辑器 1 NOTEPAD NOTEPAD 是一款免费又优秀的文本编辑器 支持在 MS Windows 环境下运
  • 全网最完整php禁用eval函数讲解

    1 eval是什么 eval是一个语言构造器 并不是系统组件函数 因此我们在php ini中使用disable functions是无法禁止它的 2 eval的危害 eval 对于php安全来说具有很大的杀伤力 因此一般不用的情况下为了防止
  • Linux下 C 遍历目录(opendir,readdir函数)

    opendir 函数 头文件 include
  • 如何用清华 ChatGLM 微调一个私域大模型

    曹政 曹大是我们圈子里公认的大佬 他在技术上不仅早早领先 在思维认知领域更是帮助很多小伙伴快速成长 没有 ChatGPT 之前 我一直在想 能否将曹大的思维 直接植入过来 就跟无崖子传输功力 头碰头就行 当然我多想了 ChatGPT 出来后

随机推荐

  • EXT.JS2.2表单上传文件

    var uploadFile new Ext form TextField fieldLabel 上传文件 id file name uploadFile height 25 width 860 blankText 请上传文件 itemCl
  • React中怎么实现状态自动保存(KeepAlive)?

    什么是状态保存 移动端中 用户访问了一个列表页 上拉浏览列表页的过程中 随着滚动高度逐渐增加 数据也将采用触底分页加载的形式逐步增加 列表页浏览到某个位置 用户看到了感兴趣的项目 点击查看其详情 进入详情页 从详情页退回列表页时 需要停留在
  • 关于STM32 定时器PWM输出,关闭PWM时,输出引脚电平控制。

    STM32的定时很多 功能也比较全面 pwm功能更是比较常用的功能 特别是对直流电机调速使用 但是有时我们停止PWM的时候希望 PWM的输出通道输出固定电平 下面我说一下其中的一种实现方法 根据数据手册得知 只要将OC1M设置为 100或者
  • 鞋子AJ,表格AG,ag-grid社区版排序错误问题

    ag grid表格数字格式排序是按照1 10 11 2 3 4这样排序的 相信很多小伙伴都知道怎么解决 只需要在sort方法内arr sort function a b return a b 就可以 我之前在源码里找到了这个 但是没法解决
  • 李峋同款爱心Python代码版来了

    最近看到不少关于李峋同款爱心的视频 文章 今天我们也分享一下李峋同款爱心 Python 代码版 简单来说李峋同款爱心就是一个动态的 型效果 主要 Python 代码实现如下 def init self generate frame 20 原
  • Python自动化测试的配置层实现方式对标与落地

    Python中什么是配置文件 配置文件如何使用 有哪些支持的配置文件等内容 话不多说 让我们一起看看吧 1 什么是配置文件 配置文件是用于配置计算机程序的参数和初始化设置的文件 如果没有这些配置程序可能无法运行或是影响运行 运行速度 便捷性
  • C# 使用SqlDataReader读取数据库数据

    本文主要讲述如何使用SqlDataReader方法来读取数据 来完成数据库增删改查中查的工作 这是C 读取数据库的主要方法 一 环境介绍 Visual Studio 2015 SQL Server 2012 控制台应用程序 使用的数据库名称
  • 在Gitee搭建属于自己的博客

    搭建属于自己的私人博客 工具安装 1 安装 git git 版本控制工具 链接 https pan baidu com s 19V8BH4kO9h6eVNFhMzAU4w 提取码 chgo 1 1 选择 next 1 2 选择安装路径 1
  • 全球十大即时通信软件最新排名

    第十名 Signal 1亿用户 Signal是一款提供加密通信的即时通讯软件 用户可以进行点对点的私密聊天和通话 优势 客户端及服务器开源 默认私聊 群聊端对端加密 纯净无广告 没有复杂功能 局限 注册使用Signal必须与手机捆绑 无法在
  • SQL数据库编写及示例

    一 数据库编写 1 数据库常用约束 主键约束 primary key 外键约束 foreign key references 唯一值约束 unique 默认值约束 default 检查约束 check 非空约束 not null 标识列 i
  • Apolo学习

    安装 java1 8 mysql 5 6 5以上 下载quickStart的包 早apollo下执行两个sql 如果不执行这两个sql apollo是执行不起来的 会有两个表来记录apollo的执行情况 其中一个表叫apolloportal
  • Sass语法(三)之循环

    一 数据类型 1 数字 如 1 2 13 10px 2 字符串 有俩种类型 a 有引号字符串 quoted strings 如 Lucida Grande http sass lang com b 无引号字符串 unquoted strin
  • C语言--指针:最底层的解释(慢慢懂~)

    指针 又可以叫它为地址 他表示的就是变量的被存储的地址 举个例子 创建整型变量a 于是a被存储到了内存中 我们就可以通过创建指针来找到他被存储到了哪个位置 取地址操作符 我们可以打印出a的指针 在这里 p为指针变量 指向a 不同于指针 打印
  • C++STL之vector与list

    文章目录 关于vector的用法 关于List的用法 vector和list的区别 关于vector的用法 include
  • C++ 享元模式

    什么是享元模式 享元模式是一种结构型设计模式 实现了在较少内存开销的同时 又支持了大量的对象 主要在资源有限的情况下 对创建大量对象行为的一种约束行为 享元模式的适用特征 当程序中有大量的相同对象 这些对象消耗了大量的内存 这些对象的状态可
  • centos7系统引导自动重启_Linux老鸟给出的Linux系统故障问题汇总,值得永久收藏...

    一 处理linux系统故障的思路 作为一名优秀的linux运维工程师 一定要有一套清晰 明确的解决故障思路 当问题出现时 才能迅速定位 解决问题 在开始本文学习之前 我根据多年工作和处理问题和故障的经验 总结出了一套处理问题的一般思路 供大
  • 全卷积网络FCN详细讲解(超级详细哦)

    原文链接 https blog csdn net qq 41760767 article details 97521397 depth 1 utm source distribute pc relevant none task utm so
  • Job thrrew an unhandled exception 是什么报错

    Job threw an unhandled exception 是一个通用的错误信息 它表明在执行一个作业 Job 时发生了未处理的异常 这个错误信息并不提供具体的异常信息 而只是告诉你作业执行过程中出现了未处理的异常 并且该异常没有被适
  • HSQLDB 介绍

    HSQLDB HSQL使用 java 语言编写的免费数据库 相对其他数据库 体积很小 是一个非常轻量级的数据库 不需要安装 而且支持嵌套查询和Indentity主键 下面结合在程序中使用 对 HSQL 作个简要的介绍和使用 一 简介 HSQ
  • ABAP DOI详解(1)

    什么是 DOI DOI 是Desktop Office Integration的缩写 是 SAP 提供的解决与 Office 集成的技术方案 早期 SAP 用 OLE 技术解决 与 Office 集成 OLE 语法参照 VBA 在 ABAP