cl_demo_output=>display 介绍
Methods of CL_DEMO_OUTPUT
PS:自己测试是display后的内表不能带表头。
类CL_DEMO_OUTPUT 在示例程序中创造了很多简单的数据输出的方法而不需要经典的list。这个类可以通过静态或实例化的方式使用。下面这些方法在输出流中创建输出。
- 方法BEGIN_SECTION,NEXT_SECTION和END_SECTION创建标题和开始或结束标题级别。
- 方法WRITE_DATA,WRITE_TEXT,WRITE_XML,WRITE_JSON和WRITE_HTML显示不同类型的输出。
- 使用WRITE_DATA可以输出基本类型对象(不是引用类型),结构的组件和内表的行类型。
- 其它方法创建格式化的输出数据如xml ,json,HTML。
- 方法写是通用的。它处理ABAP数据和文本(非比例格式)。
- 方法DISPLAY_……(只提供静态方法)工作方式为WRITE_…,但请关闭当前输出流并打开一个新的输出流。如果SAP GUI可用,则输出将显示在窗口中。
- 方法行创建一个横向行。
- 方法DISPLAY关闭当前输出流并打开一个新的输出流。如果SAP GUI可用,则输出将显示在窗口中。还可以选择像forWRITE一样传递数据来显示。
- 方法GET的工作方式与DISPLAY类似,但不显示数据。相反,格式化的输出数据以文本字符串的形式返回,可以进一步处理。
- 标准输出格式是HTML。您还可以选择使用制表器和换行符来选择简单的文本格式。您可以为静态方法选择带有SET_MODE方法的格式,也可以为实例方法选择factory methodNEW的输入参数模式。
- CL_DEMO_OUTPUT类在自SP07以来的7.03/7.31版本和更高版本中可用。它有一个类文档。
代码示例
最简单和常见的用法如下:
SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
CL_DEMO_OUTPUT=>DISPLAY( IT_TAB ).

使用CL_DEMO_OUTPUT的多个静态方法的程序可能如下所示:
SELECT * FROM SCARR INTO TABLE @DATA(CARRIERS).
CALL TRANSFORMATION ID SOURCE CARRIERS = CARRIERS
RESULT XML DATA(XML).
CL_DEMO_OUTPUT=>BEGIN_SECTION( `Some Text` ).
CL_DEMO_OUTPUT=>WRITE_TEXT( |blah blah blah \n| && |blah blah blah| ).
CL_DEMO_OUTPUT=>NEXT_SECTION( `Some Data` ).
CL_DEMO_OUTPUT=>BEGIN_SECTION( `Elementary Object` ).
CL_DEMO_OUTPUT=>WRITE_DATA( CARRIERS[ ]-CARRID ).
CL_DEMO_OUTPUT=>NEXT_SECTION( `Internal Table` ).
CL_DEMO_OUTPUT=>WRITE_DATA( CARRIERS ).
CL_DEMO_OUTPUT=>END_SECTION( ).
CL_DEMO_OUTPUT=>NEXT_SECTION( `XML` ).
CL_DEMO_OUTPUT=>WRITE_XML( XML ).
CL_DEMO_OUTPUT=>DISPLAY( ).

由于这看起来很丑陋,如果你在一个程序中调用了类的3到4个以上的方法,最好使用实例方法而不是静态方法:
CL_DEMO_OUTPUT=>NEW(
)->BEGIN_SECTION( `Some Text`
)->WRITE_TEXT( |blah blah blah \n| && |blah blah blah|
)->NEXT_SECTION( `Some Data`
)->BEGIN_SECTION( `Elementary Object`
)->WRITE_DATA( CARRIERS[ ]-CARRID
)->NEXT_SECTION( `Internal Table`
)->WRITE_DATA( CARRIERS
)->END_SECTION(
)->NEXT_SECTION( `XML`
)->WRITE_XML( XML
)->DISPLAY( ).

静态方法和实例方法如何具有相同的名称?
实例方法是接口方法。方法NEW返回一个类型为IF_DEMO_OUTPUT的引用变量。这个接口由CL_DEMO_OUTPUT实现。接口方法具有与类的静态方法相同的名称。
为什么要将这些方法链接起来呢?
为了方便起见,每个实例方法都返回自我参考。
如果你想要一个更简单的输出,你可以切换到文字模式:
SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
CL_DEMO_OUTPUT=>new( 'TEXT' )->DISPLAY( it_tab ).

如果你想自己处理生成的格式化数据,你可以使用GET而不是DISPLAY:
SELECT * FROM SCARR INTO TABLE @DATA(IT_TAB).
DATA(HTML) = cl_demo_output=>GET( it_tab ).
CL_ABAP_BROWSER=>SHOW_HTML( HTML_STRING = HTML ).
这将产生与上面第一个示例相同的输出。

您还可以检查和运行以下程序,以获得所有可能性的完整概述:
- DEMO_USAGE_OUTPUT_STATIC
- DEMO_USAGE_OUTPUT_INSTANCE
例子如下:
ADT中的ABAP关键字文档(即Eclipse中的ABAP)提供了一个框架如何使用CL_DEMO_OUTPUT的示例。如果ABAP示例库的示例使用CL_DEMO_OUTPUT,则文档框架允许您执行示例并显示输出。这是通过从cl_demo_output获取HTML输出并将其合并到(非SAP GUI)文档显示中来实现的。
另一个例子相当引人注目。CL_DEMO_OUTPUT在SAP Teched 2013上亮相!
以下是Vishal Sikka博士主题演讲的截图:
(B.t.w。,请参阅AMDP, SQLScript与Open SQL的比较,以进一步查看该示例的性能结果;上面糟糕的ABAP结果来自嵌套的SELECT循环…)。
cl_demo_output=>display 介绍的更多相关文章
- display属性详解
内容: 1.display介绍 2.display分类 3.块级标签和内联标签 4.inline-block应用 1.display介绍 display:display属性设置元素如何被显示 2.di ...
- ABAP中的AMDP(ABAP-Managed Database Procedures )
ABAP管理下的数据库存储过程(ABAP-Managed Database Procedure,以下简称AMDP)是在APAP on SAP HANA开发中的一种优化模式.AMDP使用数据库语言书写, ...
- 我的BRF+自学教程(一):公式(formula)
Business Rule Framework Plus(业务规则框架,以下简称BRFplus或BRF+)是一个强大的工具, 它允许用户以直观的方式对规则建模,并在不同的应用程序中重用这些规则.通过它 ...
- 【第四篇】SAP ABAP7.5x新语法之CREATE DATA&INTERFACE
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文地址:SAP ABAP7.5x系列之CREATE DA ...
- ABAP实现Geohash
前几天群里有人问ABAP有没有Geohash函数,用来帮助SAP存储门店位置.实现对附近门店查找的功能.因为没有查到,所以我动手写了一个. Geohash是什么 Geohash是一种公共域地理编码系统 ...
- ABAP实现Blowfish加密算法
看到SAP社区中有人问是否存在ABAP实现的Blowfish加密算法,无人回答.于是动手实现了一个blowfish-abap.通过blowfish-abap可以在SAP系统中使用Blowfish对数据 ...
- 动态SQL屏幕条件选择(里面还有赋值的新语法)
有时候屏幕条件中使用PARAMETERS时候,如果你为空的话,会查不出数据,但是可能你的想法是不想限制而已,但是系统默认理解为了空值,这个时候,如果取判断一下条件是不是空,在SQL里决定写不写的话,会 ...
- ABAP 7.4 新语法-内嵌生命和内表操作
1.内嵌声明 2.内表操作 3.opensql ************************************************************************ 1. ...
- ABAP 7.52 中的Open SQL新特性
S/4 HANA 1709 已经在几个月前发布,随之而来的是ABAP 7.52. 本文翻译了更新文档中有关Open SQL的部分 本文链接:http://www.cnblogs.com/hhelibe ...
随机推荐
- 洛谷 SP263 Period
洛谷 SP263 Period 题目描述 For each prefix of a given string S* with N* characters (each character has an ...
- Ruby入门1
由于部门的自动化是由一个前辈实现的,他使用的Ruby的语言来实现的,所以需要学习一下Ruby语言,争取在15天左右可以掌握Ruby语言!加油~~~ 1.常量&变量 # 1.常量 # 一般用大写 ...
- ZooKeeper(六):watch机制的原理与实现
因为ZK有watch机制,可以随时发现一些数据的变化,从而达到数据的及时性. ZK的所有读操作都可以设置watch监视点: getData, getChildren, exists. 写操作则是不能设 ...
- python Windows环境下文件路径问题
转自:http://blog.sina.com.cn/s/blog_5ee7254801013zu7.html 在python程序里面我们经常需要对文件进行操作,Windows下的文件目录路径使用反斜 ...
- 【C++常用函数】头文件<algorithm>中的常用函数(绝对值,交换,比较)
swap(a,b) 用于交换a,b两个变量的值: max(a,b) 返回a,b中的最大值: min(a,b) 返回a,b中的最小值: abs(x) 返回x的绝对值,x必须是整数:
- Oracle数据库之第四篇
/* 授权命令 grant 权限 to 用户 授权可以授予多个权限 grant connect,resource to baidu 收回权限 revoke 权限 from 用户 revoke dba ...
- cmdb项目-1
1.什么是cmdb 配置管理数据库 ,存储基础设备的各种信息配置等 CMDB可以存储并自动发现整个IT网络上的各种信息,比如一个IT网络上有多少台服务器.多少存储.设备的品牌.资产编号.维护人员.所属 ...
- git clone克隆项目太慢,或者直接导致克不下来的解决办法(转载请注明出处)
从github下载项目下来,由于项目提交历史过多等各种原因导致文件太大,clone的时候非常的慢,或者直接出现 error: RPC failed; curl 18 transfer closed w ...
- ArcGIS以数据库作为数据源作为source发布服务步骤详解(以Postgresql为例)及各种发布问题
创建企业级数据库 Data Management Tools-->Geodatabase Administration-->Create Enterprise Geodatabase 按如 ...
- vue-cli 项目启动过程分析
启动时没有加入路由 先npm run dev 把项目启动起来.看到 这个熟悉的界面. 首先看到: 这是项目的入口文件,一般引用其他的js,也都是在这个文件进行引用的. 渲染的时候,就是对这个id=&q ...