使用ABAP操作Excel的方法有哪些

发布时间:2021-12-29 16:51:23 作者:iii
来源:亿速云 阅读:141

本篇内容介绍了“使用ABAP操作Excel的方法有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

在SAPGUI里根据关键字OLE搜索,能找到通过ABAP操作Excel的一种办法:

使用ABAP操作Excel的方法有哪些

这段文档说的比较清楚,微软的Word和Excel这种Office应用,提供了一种所谓automation的接口,暴露的公有类的方法和属性可以被其他应用消费。

作为ABAP应用开发人员,我们通过调用OLE对象的方法CALL METHOD, GET PROPERTY,SET PROPERTY等来访问微软Word和Excel的automation接口,代码看起来像这样:

使用ABAP操作Excel的方法有哪些

上面这个函数RH_START_EXCEL_DATA_OLE调用微软Excel的automation接口,新建一个Excel workbook,然后准备把ABAP内表里的数据写到Excel里。

你也许会问,我咋知道Excel里有哪些公有的类和方法可以被ABAP调用呢?

在Excel里点击右键,选择View Code:

使用ABAP操作Excel的方法有哪些

打开Microsoft Visual Basic Object Brower,所有可用的类和方法都列在这里了,上面ABAP代码第218行调用的workbook的open方法在列表里也能找到。

使用ABAP操作Excel的方法有哪些

这个解决方案只在windows平台有效,并且需要运行SAPGUI的Presentation Server上安装有微软的Excel应用。

我们采用OLE的方式操作Excel时,打开Windows操作系统的任务管理器,会发现一个以/automation -Embedding参数启动的Excel进程。

使用ABAP操作Excel的方法有哪些

这里的-Embedding参数,来自OLE的全称:Object Linking and Embedding里的一部分。OLE是微软的一项非常古老的技术了。

使用ABAP操作Excel的方法有哪些

微软和SAP两位大佬,Bill Gates和Hasso Plattner 1993年的照片:

使用ABAP操作Excel的方法有哪些

关于OLE,Jerry知道的就这么点了,在SAP研究院里如今我们还是会和微软的技术打交道,比如微软的Azure.

使用ABAP操作Excel的方法有哪些

如果Jerry没记错的话, 微软Office从2007版本开始, 采用新的支持Office Open XML标准的格式来管理Excel和Word等文件。Jerry 2014年在SAP成都研究院CRM开发团队负责CRM Document Builder这个模块,当时编写过使用ABAP操作Word文档的代码。

以Word为例,下图是我创建了一个最简单的Word文档,包含了一个Header区域,一个由三行彩色文字组成的段落,还有一张图片。

使用ABAP操作Excel的方法有哪些

我们把这个Word文档的扩展名从.docx改成.zip, 然后双击,就可以用解压软件比如winrar打开。

于是发现这一个最简单的按照Office Open XML协议实现的Word文档,实际上由如此多的xml和文件夹构成。

使用ABAP操作Excel的方法有哪些

使用SAP标准的类CL_DOCX_DOCUMENT读取Word文件内容:

使用ABAP操作Excel的方法有哪些

上述代码的简要说明:

(1) 将word文档的二进制内容传入方法cl_docx_document=>load_document,得到一个文档对象引用,然后就可以借助该对象引用调用各种方法了。

(2) word文档的创建者,创建时间,最后修改时间等信息都存储在所谓的“Core property part”内,可以通过方法lo_document->get_corepropertiespart获得"Core property part"的引用,再使用该引用调用方法get_data获得实际内容。

下图是get_data返回的内容的一个例子,可以看出是xml格式。

使用ABAP操作Excel的方法有哪些

(3) 现在我们准备读取Word文档的正文了。使用方法lo_document->get_maindocumentpart得到Word文档正文,文字的字体类型,颜色也包含在内。如下图所示:

使用ABAP操作Excel的方法有哪些使用ABAP操作Excel的方法有哪些

(4) Word文档里插入的图片的二进制内容当然也是可以读取出来的。使用方法:lo_image_parts->get_part返回。

Excel的例子我没有动手做过,不过原理类似,大家可以用开发包S_OOXML_CORE里的CL_XLSX_DOCUMENT来操作格式为xlsx的Excel文档。

使用ABAP操作Excel的方法有哪些

除此之外,还有一个著名的开源项目, abap2xlsx, Jerry没有试过,感兴趣的朋友可以试试。

使用ABAP操作Excel的方法有哪些

最后,大家在SE24里使用关键字XSLX以及SE38里搜索_OLE,

使用ABAP操作Excel的方法有哪些

可以从搜索列表里选一些点进去,参考SAP标准程序是如何操作Excel文档的。

使用ABAP操作Excel的方法有哪些

“使用ABAP操作Excel的方法有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

推荐阅读:
  1. 使用openpyxl操作Excel
  2. python操作excel的方法(xlsxwriter包的使用)

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

abap excel

上一篇:shell中grep和正则表达式怎么用

下一篇:notepad++中正则表达式删除某行某字符开始之前或者之后所有字符是什么

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》