abap 操作 excel

一个不错的操作 excel 的文章
https://www.elearningsolutions.co.in/a-to-z-of-ole-excel-in-abap-7-4-2/

重点

workbooks 和 workbook 是两个变量,open、saveAs 的时候都用 workbook

复制代码
 CALL METHOD OF lo_excel 'Workbooks' = lo_workbooks.
  CALL METHOD OF lo_workbooks 'Open' = lo_workbook
    EXPORTING
      #1 = file_mal.

完整代码

复制代码
REPORT z_save_excel.

*----------------------------------------------------------------------*
*  DATA DECLARATIONS
*----------------------------------------------------------------------*
DATA: lo_excel       TYPE  ole2_object,  " Excel 应用对象
      lo_workbooks   TYPE  ole2_object,  " 工作簿集合
      lo_workbook    TYPE  ole2_object,  " 当前工作簿
      lo_worksheet   TYPE  ole2_object,  " 当前工作表
      lo_range       TYPE  ole2_object,
      lv_template    TYPE string,              " 模板文件路径
      lv_save_path   TYPE string,              " 保存路径
      lv_msg         TYPE string.              " 消息文本

*----------------------------------------------------------------------*
*  MACRO: 安全释放 OLE 对象
*----------------------------------------------------------------------*


*----------------------------------------------------------------------*
*  START-OF-SELECTION
*----------------------------------------------------------------------*
START-OF-SELECTION.
  PARAMETERS file_mal(100) TYPE c LOWER CASE DEFAULT 'D:\Template.xlsx'.
    PERFORM genexcel.
    write: 'finish', file_mal.

form genexcel.
  lv_template = 'D:\Template.xlsx'.  " 示例:本地模板文件路径

  lv_save_path = 'D:\Hello_ABAP.xlsx'.
  CREATE OBJECT lo_excel 'excel.application'.
  IF sy-subrc <> 0.
    MESSAGE '无法启动 Excel 应用,请检查是否安装 Excel' TYPE 'E'.
  ENDIF.


*  # 设置 Excel 可见性,便于调试(完成后可以注释掉)
  SET PROPERTY OF lo_excel 'visible' = 1.

  CALL METHOD OF lo_excel 'Workbooks' = lo_workbooks.
  CALL METHOD OF lo_workbooks 'Open' = lo_workbook
    EXPORTING
      #1 = file_mal.

  CALL METHOD OF lo_workbook 'Worksheets' = lo_worksheet
    EXPORTING
      #1 = 1.  " 1 表示第一个工作表(Sheet1)
   " 使用Range方法直接操作A1单元格
  CALL METHOD OF lo_worksheet 'Range' = lo_range
    EXPORTING
      #1 = 'A1'.

  " 在A1单元格写入值
  SET PROPERTY OF lo_range 'Value' = 'hello world'.

  CALL METHOD OF lo_workbook 'SaveAs'
    EXPORTING
      #1 = lv_save_path.

  MESSAGE '文件已保存至:' && lv_save_path TYPE 'S'.



  CALL METHOD OF lo_workbook 'Close'
    EXPORTING
      #1 = ABAP_FALSE. " 关闭时不再次保存
ENDFORM.
相关推荐
yaoxin5211233 小时前
397. Java 文件操作基础 - 创建常规文件与临时文件
java·开发语言·python
dFObBIMmai3 小时前
MySQL主从同步中大事务导致的延迟_如何拆分大事务优化同步
jvm·数据库·python
szccyw03 小时前
mysql如何限制特定存储过程执行权限_MySQL存储过程安全访问
jvm·数据库·python
czlczl200209253 小时前
利用“延迟关联”优化 MySQL 巨量数据的深分页查询
数据库·mysql
ACP广源盛139246256734 小时前
IX8024与科学大模型的碰撞@ACP#筑牢科研 AI 算力高速枢纽分享
运维·服务器·网络·数据库·人工智能·嵌入式硬件·电脑
Elastic 中国社区官方博客4 小时前
ES|QL METRICS_INFO 和 TS_INFO:为你的时间序列数据建立目录
大数据·数据库·elasticsearch·搜索引擎·信息可视化·全文检索
俺不要写代码4 小时前
数据库:函数
数据库·mysql
2401_882273725 小时前
如何在 CSS 中正确加载本地 JPG 背景图片
jvm·数据库·python
极客先躯5 小时前
高级java每日一道面试题-2025年11月24日-容器与虚拟化题[Dockerj]-runc 的作用是什么?
java·oci 的命令行工具·最小可用·无守护进程·完全标准·创建容器的核心流程·runc 核心职责思维导图
用户60648767188965 小时前
AI 抢不走的技能:用 Claude API 构建自动化工作流实战
java