EXCEL上传得时候特殊情况

比如excel里面不全是我们需要的,还有一些需要处理EXCEL中的日期,去掉‘-’等

DATA:begin_row TYPE i VALUE '2',begin_col TYPE i VALUE '1',end_row   TYPE i VALUE '9999',end_col   TYPE i VALUE '90',filename  TYPE rlgrap-filename,gt_excel  TYPE zalsmex_tabline OCCURS 0 WITH HEADER LINE,gt_excel_copy  TYPE zalsmex_tabline OCCURS 0 WITH HEADER LINE,num       TYPE i,rt_col    TYPE RANGE OF kcd_ex_col_n,rs_col    LIKE LINE OF rt_col,_n_r      TYPE char2,_r        TYPE char1.FIELD-SYMBOLS <fs> .REFRESH:gt_gts_file_line_copy,gt_gts_file_line_2,gt_gts_file_line._n_r = cl_abap_char_utilities=>cr_lf._r = _n_r+1(1).rs_col-sign    = 'I'.rs_col-option  = 'EQ'.rs_col-low     = '0002'.APPEND rs_col TO rt_col.rs_col-low     = '0006'.APPEND rs_col TO rt_col.rs_col-low     = '0010'.APPEND rs_col TO rt_col.rs_col-low     = '0011'.APPEND rs_col TO rt_col.rs_col-low     = '0012'.APPEND rs_col TO rt_col.rs_col-low     = '0013'.APPEND rs_col TO rt_col.rs_col-low     = '0014'.APPEND rs_col TO rt_col.rs_col-low     = '0015'.APPEND rs_col TO rt_col.rs_col-low     = '0016'.APPEND rs_col TO rt_col.rs_col-low     = '0017'.APPEND rs_col TO rt_col.rs_col-low     = '0019'.APPEND rs_col TO rt_col.rs_col-low     = '0020'.APPEND rs_col TO rt_col.rs_col-low     = '0021'.APPEND rs_col TO rt_col.rs_col-low     = '0022'.APPEND rs_col TO rt_col.rs_col-low     = '0023'.APPEND rs_col TO rt_col.rs_col-low     = '0024'.APPEND rs_col TO rt_col.rs_col-low     = '0025'.APPEND rs_col TO rt_col.rs_col-low     = '0029'.APPEND rs_col TO rt_col.rs_col-low     = '0054'.APPEND rs_col TO rt_col.rs_col-low     = '0055'.APPEND rs_col TO rt_col.rs_col-low     = '0056'.APPEND rs_col TO rt_col.rs_col-low     = '0057'.APPEND rs_col TO rt_col.rs_col-low     = '0058'.APPEND rs_col TO rt_col.rs_col-low     = '0060'.APPEND rs_col TO rt_col.rs_col-low     = '0063'.APPEND rs_col TO rt_col.rs_col-low     = '0064'.APPEND rs_col TO rt_col.filename = p_path.CALL FUNCTION 'ZALSM_EXCEL_TO_INTERNAL_TABLE'EXPORTINGfilename    = filenamei_begin_col = begin_coli_begin_row = begin_rowi_end_col   = end_coli_end_row   = end_rowTABLESintern      = gt_excel[].IF gt_excel[] IS INITIAL.MESSAGE '请填充数据' TYPE 'S' DISPLAY LIKE 'E'.
*    .EXIT.ENDIF.SORT gt_excel[] BY row col value.
*  DELETE gt_excel[] WHERE col NOT IN rt_col.*&--------------added by handlmq 17.05.2024 13:04:31  begin---------------------&*
data:I(2) TYPE I.gt_excel_copy[] = gt_excel[].DATA:zn TYPE kcd_ex_row_n.DATA:n  TYPE kcd_ex_col_n.LOOP AT gt_excel_copy.ON CHANGE OF gt_excel_copy-row.zn = gt_excel_copy-row.CLEAR:n.ENDON.n = n + 1.IF n <> gt_excel_copy-col.I = gt_excel_copy-col - n.DO I  TIMES.gt_excel-col = n.gt_excel-row = zn.APPEND gt_excel.n = n + 1.ENDDO.ENDIF.ENDLOOP.
*&--------------added by handlmq 17.05.2024 13:04:31  end-----------------------&*SORT gt_excel[] BY row col value.DELETE gt_excel[] WHERE col NOT IN rt_col.LOOP AT gt_excel.ON CHANGE OF gt_excel-row.IF sy-tabix NE 1.APPEND gs_gts_file_line_copy TO gt_gts_file_line_copy.CLEAR: gs_gts_file_line_copy,num.ENDIF.ENDON.num = num + 1.ASSIGN COMPONENT num OF STRUCTURE gs_gts_file_line_copy TO <fs>.IF <fs> IS ASSIGNED .IF num = 18.REPLACE '-' INTO gt_excel-value WITH ``.REPLACE '-' INTO gt_excel-value WITH ``.ENDIF.IF num = 17.REPLACE ALL OCCURRENCES OF _r IN gt_excel-value WITH ` `.REPLACE ALL OCCURRENCES OF '"' IN gt_excel-value WITH ''.ENDIF.<fs> =  gt_excel-value.UNASSIGN <fs>.ENDIF.ENDLOOP.APPEND gs_gts_file_line_copy TO gt_gts_file_line_copy.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/22088.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

AI产品经理系列-如何使用kimi快速撰写用户故事(含提示词)

在AI时代&#xff0c;可能人人都可成为产品经理。 之前我们聊过如何使用kimi协助完成产品需求文档&#xff0c;如何写竞品分析报告&#xff0c;这一篇我们聊聊用户故事&#xff0c;如何使用kimi协助撰写产品需求文档中的用户故事。 在此之前我们先了解下什么是用户故事&#…

深入理解Django Serializer及其在Go语言中的实现20240604

深入理解Django Serializer及其在Go语言中的实现 在现代Web开发中&#xff0c;前后端分离已成为主流架构模式。作为开发者&#xff0c;我们经常需要处理数据的序列化和反序列化&#xff0c;以便在前后端之间传递数据。在Django中&#xff0c;Serializer是一个强大的工具&#…

Spring类加载机制揭秘:深度解析“验证”阶段

1. 引言 在Spring框架中&#xff0c;类加载机制是一个至关重要的环节&#xff0c;它确保了应用程序在运行时能够正确地加载、链接和初始化所需的类。其中&#xff0c;验证&#xff08;Verification&#xff09;作为类加载机制的一个重要阶段&#xff0c;起到了至关重要的作用。…

车牌号码智能监测识别摄像机

车牌号码智能监测识别摄像机是一项革命性的技术&#xff0c;为交通管理和安全提供了全新的解决方案。这种摄像机利用先进的人工智能和图像识别技术&#xff0c;能够实时监测道路上的车辆&#xff0c;并准确识别车辆的车牌号码&#xff0c;为交通管理和安全提供了强有力的支持。…

java 工作排序(Job Sequencing Problem)

给定一个作业数组&#xff0c;其中每个作业都有一个截止期限&#xff0c;如果作业在截止期限之前完成&#xff0c;则可获得相关利润。此外&#xff0c;每个作业都占用一个单位时间&#xff0c;因此任何作业的最小可能截止期限都是 1。如果一次只能安排一项作业&#xff0c;则最…

代码随想录算法训练营Day60 | 84.柱状图中最大的矩形 | Python | 个人记录向

注&#xff1a;今天是代码随想录训练营的最后一天啦&#xff01;&#xff01;&#xff01; 本文目录 84.柱状图中最大的矩形做题看文章 以往忽略的知识点小结个人体会 84.柱状图中最大的矩形 代码随想录&#xff1a;84.柱状图中最大的矩形 Leetcode&#xff1a;84.柱状图中最…

解决使用Python检查本地网络中运行的Web服务器的问题

如果我们要检查本地网络中运行的 Web 服务器&#xff0c;可以使用 Python 的 socket 模块来进行网络连接测试。以下是一个简单的示例代码&#xff0c;演示如何检查本地网络中运行的 Web 服务器&#xff1a; 1、问题背景 在学习如何使用 Python 时&#xff0c;一位用户希望编写…

从零开始:腾讯云轻量应用服务器上部署MaxKB项目(基于LLM大语言模型的知识库问答系统)

使用腾讯云轻量应用服务器部署和使用MaxKB项目 前言 一&#xff0c; MaxKB介绍 MaxKB是基于LLM大语言模型的知识库问答系统&#xff0c;旨在成为企业的最强大脑。它支持开箱即用&#xff0c;无缝嵌入到第三方业务系统&#xff0c;并提供多模型支持&#xff0c;包括主流大模型…

我们如何收到卫星信号?(导航电文,载波与测距码)

卫星信号 在介绍所有卫星信号之前&#xff0c;首先要明确一些概念&#xff1a; 所有的卫星信号&#xff0c;都是一段电磁波&#xff0c;用户接收的&#xff0c;也是一段电磁波。 但是我们认知中的电磁波&#xff0c;就是一段波&#xff0c;就像我们打出去的交一样&#xff0c…

【UML用户指南】-03-UML的14种图

目录 1、结构图 1、类图&#xff08;class diagram&#xff09; 2、对象图&#xff08;object diagram&#xff09; 3、构件图 &#xff08;component diagram&#xff09; 4、组合结构图 5、包图&#xff08;package diagram&#xff09; 6、部署图&#xff08;deploym…

Android输入法IME(二)

2. IME初始化启动流程 2.1. IME客户端&#xff08;IMM&#xff09;初始化流程 涉及代码文件路径&#xff1a; frameworks/base/core/java/android/view/ViewRootImpl.java frameworks/base/core/java/android/view/WindowManagerGlobal.java frameworks/base/core/java/andro…

【kubernetes】k8s的面试宝典,等你来拿哦

目录 一、pod的生命周期 二、创建 pod 的工作流程 三、ingres 有哪些组件并且描述出组件作用 &#xff1f; 四、ingress 的工作原理 五、ingress 暴露服务的方式 六、pod 的组成 七、pod的本身性质&#xff08;pod的种类与说明&#xff09; 八、k8s命令 8.1在k8s中如何…

零基础入门学习Python第二阶04SQL详解03

MySQL 新特性 JSON类型 很多开发者在使用关系型数据库做数据持久化的时候&#xff0c;常常感到结构化的存储缺乏灵活性&#xff0c;因为必须事先设计好所有的列以及对应的数据类型。在业务发展和变化的过程中&#xff0c;如果需要修改表结构&#xff0c;这绝对是比较麻烦和难…

AppStore搜索优化方法(ASO)

在竞争激烈的 App Store 中&#xff0c;如何让你的应用脱颖而出&#xff0c;吸引更多用户下载&#xff1f;其实从官方文档描述中可以总结一些优化技巧&#xff0c;这是官方描述地址&#xff1a;搜索优化 – App Store – Apple Developer。通过官方描述我们可以总结到影响搜索结…

commander.js 入门指南:构建强大的命令行界面 (全网最全教程)

在Node.js的世界里&#xff0c;创建用户友好的命令行界面&#xff08;CLI&#xff09;对于许多应用程序和工具来说至关重要。Commander.js 是一个广受欢迎的 Node.js 包&#xff0c;它为开发者提供了一套简洁而强大的 API&#xff0c;用于快速创建功能完备、用户友好的命令行界…

如何用TCC方案轻松实现分布式事务一致性

本文作者:小米,一个热爱技术分享的29岁程序员。如果你喜欢我的文章,欢迎关注我的微信公众号“软件求生”,获取更多技术干货! 哈喽,大家好!我是小米,一个热爱技术的活力小青年,今天要和大家分享的是一种在分布式系统中实现事务的一种经典方案——TCC(Try Confirm Canc…

【Ubuntu】超详细安装Ubuntu系统

鉴于有些小伙伴在安装Ubuntu系统的时候遇到很多问题&#xff0c;因此打算编写一篇记录一下安装Ubuntu系统的整个过程~互相学习&#xff01; 一、制作U盘启动 准备一个大于8G以上的U盘&#xff0c;这里我使用的是16G的U盘下载UltraISO工具 网站地址&#xff1a;UltraISO准备Ub…

C++ Primer 第五版 第15章 面向对象程序设计

面向对象程序设计基于三个基本概念&#xff1a;数据抽象、继承和动态绑定。 继承和动态绑定对编写程序有两方面的影响&#xff1a;一是我们可以更容易地定义与其他类相似但不完全相同的新类&#xff1b;二是在使用这些彼此相似的类编写程序时&#xff0c;我们可以在一定程度上…

HTML静态网页成品作业(HTML+CSS)—— 金宝贝儿童教育机构介绍网页(2个页面)

&#x1f389;不定期分享源码&#xff0c;关注不丢失哦 文章目录 一、作品介绍二、作品演示三、代码目录四、网站代码HTML部分代码 五、源码获取 一、作品介绍 &#x1f3f7;️本套采用HTMLCSS&#xff0c;未使用Javacsript代码&#xff0c;共有2个页面。 二、作品演示 三、代…

Stable diffusion prompts 使用语法、参数讲解、插件安装教程

Stable diffusion prompts 使用语法、参数讲解、插件安装教程 本文基于 Stable diffusion WebUI 进行讲解&#xff08;安装在 AutoDL 上&#xff0c;安装在本地电脑上的也同样适用本教程&#xff09;。 初始界面&#xff1a; 文件目录结构&#xff1a; 上图红框中的 4 个文件…