news 2026/6/10 3:14:49

SAP ABAP代码实现常规数据批导(剪切板方式)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
SAP ABAP代码实现常规数据批导(剪切板方式)

SAP中经常会需要开发很多批导的程序,一般会用Excel上传数据的方式,这种经常会出现excel的各种问题,处理起来也麻烦。所以本文介绍另外一种方式,全程不使用Excel下载或者上传,使用剪切板获取模板和上传数据。

一、导出模板到剪切板

以下代码使用了AI帮我加上了注释。这里是点击选择屏幕上方的自定义按钮导出目录字段到剪切板,前提是需要在这段代码之前维护好目录。

* 变量定义(补充原代码隐含的变量定义,确保可独立运行) DATA: gt_clipboard_data TYPE TABLE OF char2048 WITH HEADER LINE, " 剪贴板输出数据内表 gt_field_catalog TYPE lvc_t_fcat WITH HEADER LINE, " ALV字段目录内表 gv_return_code TYPE sy-subrc, " 剪贴板导出返回码 gs_dfies TYPE dfies. " 数据元素信息结构(存储字段文本) CASE sscrfields-ucomm. WHEN 'FCO1'. CLEAR: gt_clipboard_data, gt_clipboard_data[]. * 遍历字段目录,筛选排除指定字段(RTYPE/RTMSG),拼接表头文本 LOOP AT gt_field_catalog WHERE fieldname <> 'RTYPE' AND fieldname <> 'RTMSG'. * 判断字段目录的列文本是否为空,为空则读取数据元素文本,否则直接使用列文本 IF gt_field_catalog-coltext = ''. * 调用系统函数读取数据元素的字段文本 CALL 'C_DD_READ_FIELD' ID 'TYPE' FIELD 'T' ID 'TABNAME' FIELD gt_field_catalog-ref_table ID 'FIELDNAME' FIELD gt_field_catalog-ref_field ID 'LANGUAGE' FIELD sy-langu. ELSE. * 字段目录有列文本,直接赋值到数据元素文本字段 gs_dfies-fieldtext = gt_field_catalog-coltext. ENDIF. * 拼接剪贴板数据:水平制表符分隔,拼接字段文本(Excel粘贴后自动分列) CONCATENATE gt_clipboard_data cl_abap_char_utilities=>horizontal_tab gs_dfies-fieldtext INTO gt_clipboard_data. ENDLOOP. * 移除拼接后字符串开头的水平制表符(避免Excel粘贴后首列空值) SHIFT gt_clipboard_data. * 将处理后的表头文本追加到剪贴板数据内表 APPEND gt_clipboard_data. * 调用GUI服务,将表头数据导出到操作系统剪贴板 CALL METHOD cl_gui_frontend_services=>clipboard_export IMPORTING data = gt_clipboard_data[] CHANGING rc = gv_return_code EXCEPTIONS cntl_error = 1 " 控件错误 error_no_gui = 2 " 无GUI环境(如后台执行) not_supported_by_gui = 3 " GUI不支持该操作 OTHERS = 4. " 其他错误 * 根据剪贴板导出结果,给出对应的消息提示 IF sy-subrc = 0. MESSAGE s000(oo) WITH '已经把表头复制到剪贴板,可以打开一个Excel文件然后粘贴'. ELSE. MESSAGE e000(oo) WITH '复制到剪贴板失败'. ENDIF. * 其他操作码:无处理逻辑 WHEN OTHERS. ENDCASE.

二、剪切板数据上传

以下代码是将剪切板数据导入到指定内表的form。

FORM frm_cliptoitab TABLES itab. * 常量:分割符(水平制表符) CONSTANTS: gc_tab_separator TYPE c VALUE cl_abap_char_utilities=>horizontal_tab. " 根据水平制表符分割数据 * 内表定义:剪贴板数据、分割后字段、需替换为空的符号 DATA: lt_clipboard_data TYPE TABLE OF char2048 WITH HEADER LINE, " 剪贴板导入的原始数据 lt_split_fields TYPE TABLE OF char2048 WITH HEADER LINE. " 按分隔符分割后的字段内表 * 异常相关变量 DATA: lo_exception TYPE REF TO cx_root, lv_exception_msg TYPE string. * 索引 DATA: lv_field_index TYPE sy-tabix. FIELD-SYMBOLS: <fs_target_field> , <fs_target_table> . * 赋值目标内表到字段符号 ASSIGN itab TO <fs_target_table>. * 从剪贴板导入数据 CALL METHOD cl_gui_frontend_services=>clipboard_import IMPORTING data = lt_clipboard_data[] EXCEPTIONS cntl_error = 1 error_no_gui = 2 not_supported_by_gui = 3 OTHERS = 4. IF sy-subrc <> 0. MESSAGE ID sy-msgid TYPE sy-msgty NUMBER sy-msgno WITH sy-msgv1 sy-msgv2 sy-msgv3 sy-msgv4. ENDIF. * 刷新GUI控件 CALL METHOD cl_gui_cfw=>flush. * 遍历剪贴板每行数据 LOOP AT lt_clipboard_data. CLEAR: lv_field_index, lt_split_fields[]. * 按分隔符分割当前行数据到字段内表 SPLIT lt_clipboard_data AT gc_tab_separator INTO TABLE lt_split_fields. * 遍历分割后的字段,赋值到目标内表 LOOP AT lt_split_fields. lv_field_index = lv_field_index + 1. * 分配目标内表的对应字段到字段符号 ASSIGN COMPONENT lv_field_index OF STRUCTURE <fs_target_table> TO <fs_target_field>. CHECK sy-subrc = 0. * 字段赋值 TRY . <fs_target_field> = lt_split_fields. CATCH cx_root INTO lo_exception. lv_exception_msg = lo_exception->get_text( ). ENDTRY. ENDLOOP. * 将处理后的行追加到目标内表 APPEND itab. CLEAR itab. ENDLOOP. ENDFORM.
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/5 20:56:24

再也不用手动配环境了,这个镜像全包了

再也不用手动配环境了&#xff0c;这个镜像全包了 你有没有经历过这样的深夜&#xff1a; 装CUDA版本不对&#xff0c;报错&#xff1b; pip install ms-swift卡在编译&#xff0c;等了40分钟没反应&#xff1b; 下载Qwen2.5-7B模型时断线重连三次&#xff0c;最后发现磁盘空间…

作者头像 李华
网站建设 2026/5/25 15:08:20

世毫九实验室简介·方见华致各界书

世毫九实验室方见华致各界书 近日&#xff0c;关于“世毫九”及本人的诸多言论&#xff0c;在网络间引发热议与误读。在此&#xff0c;我谨以“世毫九实验室”负责人的身份&#xff0c;作一简要澄清与说明。 首先&#xff0c;我必须坦诚&#xff0c;由于个人表达上的急切与不够…

作者头像 李华
网站建设 2026/5/24 5:49:44

测试新手百科:Postman简介、安装、入门使用方法详细攻略!

一、Postman背景介绍 用户在开发或者调试网络程序或者是网页B/S模式的程序的时候是需要一些方法来跟踪网页请求的&#xff0c;用户可以使用一些网络的监视工具比如著名的Firebug等网页调试工具。今天给大家介绍的这款网页调试工具不仅可以调试简单的css、html、脚本等简单的网…

作者头像 李华
网站建设 2026/6/6 17:24:27

Vue el-table 表尾合计行

问题&#xff1a; 前端在处理后端接口返回的列表数据进行表尾合计行统计&#xff0c;由于返回的金额不固定&#xff0c;有小数&#xff0c;整数&#xff0c;大数值等等&#xff0c;会出现累计计算数值精度丢失的问题&#xff0c;导致页面数据看起来是错的。 原因&#xff1a;…

作者头像 李华
网站建设 2026/6/6 21:35:18

面试-Tokenizer训练

1 代码 # 注&#xff1a;不建议再重复训练tokenizer&#xff08;“词典”&#xff09;&#xff0c;MiniMind已自带&#xff0c;此脚本仅供学习和参考。基于不同词典训练的模型将导致输出完全不统一&#xff0c;降低社区的模型复用性 # Note: It is not recommended to re-train…

作者头像 李华