1.create object  obj

  CREATE OBJECT EXCEL 'Excel.Application'.

这个obj通常指能够支持的应用程序

应用程序首先要满足OLE2的标准

同时还要注册到R/3系统

维护的程序信息在table: tole中可以看到

tole有个视图v_tole  可以使用tcode : sole来编辑

2.Workbook

  CALL METHOD OF EXCEL 'WORKBOOKS' = BOOKS.

a.读取现有的excel

  CALL METHOD OF BOOKS 'Open' EXPORTING #1 = p_file.

b.新建excel

  CALL METHOD OF BOOKS 'Add' .

3.Sheets

a.设置sheets的数量

  SET PROPERTY OF excel 'SheetsInNewWorkbook' = 3.

b.切换到某个sheet

  CALL METHOD OF excel 'Worksheets' = sheet EXPORTING #1 = 1.
  CALL METHOD OF sheet 'Activate'.

这个active的方法一定要调用 才能确定使用某一个sheet

c.设定名称

  SET PROPERTY OF excel 'Name' = p_sheetname.

4.合并单元格

a.确定范围

  CALL METHOD OF excel 'RANGE' = range
       EXPORTING #1 = 'A2'
                 #2 = 'E3' .

b.范围选中

  CALL METHOD OF range 'SELECT' .

c.合并单元格

  SET PROPERTY OF range 'MERGE' = 1 .

5.删除行

  CALL METHOD OF excel 'ROWS' = row
                         Exporting #1 = 2.

  CALL METHOD OF row 'DELETE'.

6.单元格着色

CALL METHOD OF excel 'cells' = cell
        EXPORTING
          #1 = 1
          #2 = 3.
GET PROPERTY OF cell 'Interior' = color.
SET PROPERTY OF color 'ColorIndex' = 35.

 

PS:

1.  GET PROPERTY OF EXCEL 'ACTIVESHEET' = SHEET.

  GET PROPERTY OF EXCEL 'ACTIVEWORKBOOK' = BOOKS.
退出时要加上这两句

否则导不出excel

 

2.关于范围range 

使用后要free掉

才能使用下一个范围

 

3.关于quit 和 free

quit是给OLE Server的

即相当于告诉excel程序退出

free是abap程序里面的object

 

4.关于使用文件操作等

例如需要指定下载到桌面

和控件相关的automation queue

注意调用cl_gui_cfw=>flush

 

5.OLE的操作也可以指定no flush

节省server 和 client 的交互

一次性传输所有的OLE操作

 

附代码:

report z_excel_demo.
type-pools: OLE2 . DATA: excel TYPE ole2_object, " Excel object
books TYPE ole2_object, " list of workbooks
sheet TYPE ole2_object, " workbook
cell TYPE ole2_object, " cell
row TYPE ole2_object, " cell
borders TYPE ole2_object, " cell
color TYPE ole2_object, " cell
range TYPE ole2_object. " cell
data: l_desktop type string. CREATE OBJECT EXCEL 'Excel.Application'. SET PROPERTY OF excel 'Visible' = 0.
SET PROPERTY OF excel 'SheetsInNewWorkbook' = 3. CALL METHOD OF EXCEL 'WORKBOOKS' = BOOKS. CALL METHOD OF BOOKS 'Add' .
* CALL METHOD OF BOOKS 'Open' EXPORTING #1 = p_file. CALL METHOD OF excel 'Worksheets' = sheet EXPORTING #1 = 1.
CALL METHOD OF sheet 'Activate'.
perform filling.
perform addition. CALL METHOD OF excel 'Worksheets' = sheet EXPORTING #1 = 2.
CALL METHOD OF sheet 'Activate'.
perform filling. GET PROPERTY OF EXCEL 'ACTIVESHEET' = SHEET.
GET PROPERTY OF EXCEL 'ACTIVEWORKBOOK' = BOOKS. * "默认导出到桌面 perform get_desktop using l_desktop. CONCATENATE l_desktop '\EXCEL_DEMO' '.xls' INTO l_desktop. call method of BOOKS 'SAVEAS'
EXPORTING
#1 = l_desktop
#2 = 1. call method of books 'CLOSE'.
call method of excel 'QUIT'. FREE OBJECT EXCEL.
message s888(sapaapdocu) with '成功导出模板:' l_desktop. form filling.
PERFORM fill_cell USING :
1 1 'Field1',
1 2 'Field2'. endform. form addition.
"合并单元格
CALL METHOD OF excel 'RANGE' = range EXPORTING #1 = 'A2' #2 = 'E3' . * 删除行
* CALL METHOD OF excel 'ROWS' = row
* Exporting #1 = 2.
* CALL METHOD OF row 'DELETE'. CALL METHOD OF range 'SELECT' . SET PROPERTY OF range 'MERGE' = 1 . free range. CALL METHOD OF excel 'RANGE' = range EXPORTING #1 = 'A5' #2 = 'M5'. CALL METHOD OF range 'Borders' = borders EXPORTING #1 = 8. SET PROPERTY OF borders 'LineStyle' = 1. CALL METHOD OF excel 'cells' = cell EXPORTING #1 = 1 #2 = 3. GET PROPERTY OF cell 'Interior' = color. SET PROPERTY OF color 'ColorIndex' = 35. SET PROPERTY OF cell 'ColumnWidth' = 20.
endform.
*-------------------------------------------------------*
* 默认导出模板到桌面
*-------------------------------------------------------*
form get_desktop using p_desktop type string .
CALL METHOD CL_GUI_FRONTEND_SERVICES=>GET_DESKTOP_DIRECTORY
changing
DESKTOP_DIRECTORY = p_desktop . CALL METHOD CL_GUI_CFW=>UPDATE_VIEW.
endform. FORM fill_cell USING p_i p_j p_val. CALL METHOD OF excel 'CELLS' = cell EXPORTING #1 = p_i #2 = p_j.
SET PROPERTY OF cell 'VALUE' = p_val. ENDFORM.

OLE-Excel基本操作的更多相关文章

  1. python3 excel基本操作及格式设置

    #encoding=utf-8 ''' excel基本操作整理 ''' #openpyxl 版本2.5.4 from openpyxl import * import datetime as dt f ...

  2. python excel基本操作

    #coding=utf-8 ''' excel基本操作 ''' from openpyxl import Workbook wb=Workbook() ws1=wb.create_sheet('sh1 ...

  3. Excel基本操作1

    Excel的基本操作之二,录入及快速填充.不足之处,欢迎补充

  4. C#操作Excel基本操作

    /// using Microsoft.Office.Core; using Microsoft.Office.Interop.Excel; using System.IO; using System ...

  5. Excel基本操作

    一.excel公式下拉 1.选择最长一列excel ,按CTRL+↓移到最后一个单元格,2光标移到下拉公式的那一列,3.再按CTRL+SHIFT+↑,4.再按CTRL+D 二.输入身份证号等长数字 方 ...

  6. MFC 简单输出EXCEL - (OLE)

    三图胜千言: 就是酱紫: //打印领料表 void CKnifeDlgDlg::PrintCurUsedTabel(int order) { // TODO: Add your command han ...

  7. Qt之excel 操作使用说明

    学习背景: 适合熟悉些qt开发,但是不是深入了解的开发者学习.具体实现(qt 5.1版本),office2007 Excel做验证,Win 7(64位),如有讲解有误,欢迎斧正! 一.简单介绍 QAx ...

  8. [SAP ABAP开发技术总结]OLE

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  9. Qt-excel文件操作方法

    版权声明:若无来源注明,Techie亮博客文章均为原创. 转载请以链接形式标明本文标题和地址: 本文标题:Qt-excel文件操作方法     本文地址:http://techieliang.com/ ...

  10. python之openpyxl模块

    一 . Python操作EXCEL库的简介 1.1 Python官方库操作excel Python官方库一般使用xlrd库来读取Excel文件,使用xlwt库来生成Excel文件,使用xlutils库 ...

随机推荐

  1. 剑指 offer set 8 树的子结构

    总结 1. 解法分为两步, 一是定位树的头结点, 二是两棵树作比较 2. 两个数作比较, 包括比较两棵树是否相等, 或者两个数是否镜像, 算法的框架类似 bool comp(root1, root2)

  2. 云服务器 ECS Linux IO 占用高问题排查方法

    https://help.aliyun.com/knowledge_detail/41224.html?spm=5176.7841174.2.19.uqC1as#使用 iostat 从系统纬度查看磁盘 ...

  3. RosettaNet

    RosettaNet 这一名字源自于 1799 年在埃及发现的 Rosetta Stone .这要追溯到公元前 196 年,该石头是在 Rosetta (Rashid) 镇附近被人发现的,上面用两种不 ...

  4. html 文件上传框 input标签

    文件上传框 有时候,需要用户上传自己的文件,文件上传框看上去和其它 文本域差不多,只是它还包含了一个浏览按钮.访问者可以通 过输入需要上传的文件的路径或者点击浏览按钮选择需要上传 的文件. 代码格式: ...

  5. [经典算法] 排列组合-N元素集合的所有子集(一)

    题目说明: 给定一组数字或符号,产生所有可能的集合(包括空集合),例如给定1 2 3,则可能的集合为:{}.{1}.{1,2}.{1,2,3}.{1,3}.{2}.{2,3}.{3}. 题目解析: 如 ...

  6. 纯CSS 多图片轮播

    今天做东西的时候,遇到一个问题关于图片轮播的问题,以前也接触过(百度 人家的demo改改..),再次遇到这个问题的时候,根据以前的印象找到了demo正信心满满的准备改一下嵌进去,发现 jquery.m ...

  7. Oracle基础 (十一)字符串函数

    一.字符串函数 LENGTH(char1,char2) SELECT LENGTH('abc def gh') FROM dual; --获取字符串的长度,包含空格 结果: CONCAT(char1, ...

  8. PHP删除符合条件的整个目录

    <?php /** * @name delFile函数与delDir函数一起使用, 删除符合条件的整个目录 * @param string $path 指定操作路径 * @return null ...

  9. Mindjet MindManager 2016/2017 折腾记录

    https://community.mindjet.com/mindjet/topics/ensure-2017-64-bit-version-installation Mindmanager sho ...

  10. Shell学习笔记 - Shell变量

    一.变量的命名 变量名必须以字母或下划线开头,由字母.数字.或下划线组成,变量名的长度不能超过255个字符. 二.变量的分类 1. 用户自定义变量 2. 环境变量 3. 位置参数变量 4. 预定义变量 ...