当前位置: 首页 > news >正文

最近顾问问了两次有没有批量更新XXX的程序,突然来了灵感

之前封装过一个更新订单的函数,正好按照这个函数做批导:CRM函数CRM_ORDER_MAINTAIN封装 - ^ω^SAP傻X^o^ - 博客园

设想的就是excel导入的第一行是函数对应结构的字段名,然后根据字段名把后面各行数据用指针对到对应的结构字段中。(item没写,因为麻烦)

随便写写的初版,后面看看能不能用上,如果有其他的需求看看要不要改改。。。

(这是CRM订单的更新,如果ECC有类型需求,可以写个通用的函数来创建订单,然后再对通用的函数(直接原函数也行)做类似操作。。。至于为什么不直接调函数,因为CRM的订单更新巨麻烦。。。)

REPORT zcrm_order_update_fc.
"根据ZCRM_ORDER_MAINTAIN_BK的参数名称,对应批导第一行字段匹配到对应的结构中
"第一列固定订单号,方便确定订单的相关信息,其他信息位置不限
"因为需要解析第一行内容,需要批导的时候就明确总列数,方便按数量去对应
"没用行项目信息,如果需要可以先将抬头和项目数据都存内表,然后按抬头内表循环处理DATA:gt_head  TYPE TABLE OF zcrm_maintain_h,gw_head  LIKE LINE OF gt_head,gt_headx TYPE TABLE OF zcrm_maintain_hx,gw_headx LIKE LINE OF gt_headx,gt_item  TYPE TABLE OF zcrm_maintain_i,lt_item  TYPE TABLE OF zcrm_maintain_i,gw_item  LIKE LINE OF gt_item,gt_itemx TYPE TABLE OF zcrm_maintain_ix,gw_itemx LIKE LINE OF gt_itemx.PARAMETERS: p_file LIKE rlgrap-filename OBLIGATORY.
PARAMETERS: p_col TYPE i OBLIGATORY."excel导入的列数量,为后面计算字段名做准备
PARAMETERS: p_line TYPE i OBLIGATORY."excel导入的行数量,为了excel函数更准确*$*$********************************************************************
*$*$    AT SELECTION-SCREEN                                            *
*$*$********************************************************************
AT SELECTION-SCREEN ON VALUE-REQUEST FOR p_file.CALL FUNCTION 'WS_FILENAME_GET'             "GET FILE NAMEEXPORTING
*     DEF_FILENAME     = ' '
*     DEF_PATH         = ' 'mask             = ',*.* ,*.*.'mode             = '0'title            = text-h10IMPORTINGfilename         = p_file
*     RC               =EXCEPTIONSinv_winsys       = 1no_batch         = 2selection_cancel = 3selection_error  = 4OTHERS           = 5.IF sy-subrc <> 0.
*            MESSAGE E016 WITH P_PATH.ENDIF.
************************************************************************
* START-OF-SELECTION                                                   *
************************************************************************
START-OF-SELECTION.PERFORM frm_upload_data.PERFORM frm_process_data.*&---------------------------------------------------------------------*
*&      Form  FRM_UPLOAD_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM frm_upload_data .DATA:lt_tab TYPE TABLE OF zalsmex_tabline,ls_tab TYPE zalsmex_tabline,wt_tab TYPE TABLE OF zalsmex_tabline,ws_tab TYPE zalsmex_tabline,v_msg  TYPE string,v_typ  TYPE string.DATA:p_start TYPE i.FIELD-SYMBOLS:<fs>  TYPE any,<fsx> TYPE any.CALL FUNCTION 'ZEXCEL_UPLOAD'EXPORTINGfilename                = p_filei_begin_col             = '1'i_begin_row             = '1'i_end_col               = p_coli_end_row               = p_lineTABLESintern                  = lt_tabEXCEPTIONSinconsistent_parameters = 1upload_ole              = 2OTHERS                  = 3.IF sy-subrc <> 0.
* Implement suitable error handling hereENDIF."固定列名内表LOOP AT lt_tab INTO ls_tab FROM 1 TO p_col.APPEND ls_tab TO wt_tab.ENDLOOP.p_start = p_col + 1.LOOP AT lt_tab INTO ls_tab FROM p_start."循环excel表格AT NEW row."新行开始,清空函数参数CLEAR:gw_head,gw_headx.ENDAT.READ TABLE wt_tab INTO ws_tab WITH KEY col = ls_tab-col."读取字段名称对应的列IF sy-subrc = 0.ASSIGN COMPONENT ws_tab-value OF STRUCTURE gw_head TO <fs>."将对应字段指定到结构IF sy-subrc = 0 AND ls_tab-value IS NOT INITIAL.<fs> = ls_tab-value."将excel值给对应结构字段ENDIF.ASSIGN COMPONENT ws_tab-value OF STRUCTURE gw_headx TO <fsx>."将对应字段指定到结构IF sy-subrc = 0 AND ls_tab-value IS NOT INITIAL.<fsx> = 'X'."将字段更新标记XENDIF.ENDIF.AT END OF row."行结束,调用函数更新CALL FUNCTION 'CONVERSION_EXIT_ALPHA_INPUT'EXPORTINGinput  = gw_head-object_idIMPORTINGoutput = gw_head-object_id.SELECT SINGLE guid sales_org process_type INTO (gw_head-guid,gw_head-sales_org,gw_head-order_type) FROM zhsb_order_index WHERE object_id = gw_head-object_id.CALL FUNCTION 'ZCRM_ORDER_MAINTAIN_BK'EXPORTINGhead       = gw_headheadx      = gw_headxIMPORTINGerror_type = v_typerror_log  = v_msg
*         OBJECT_O   =
*         TABLES
*         ITEM       =
*         ITEMX      =
*         PARTNER    =
*         PARTNERX   =
*         PRICE      =
*         PRICEX     =
*         TEXT       =
        .ENDAT.ENDLOOP.ENDFORM.
*&---------------------------------------------------------------------*
*&      Form  FRM_PROCESS_DATA
*&---------------------------------------------------------------------*
*       text
*----------------------------------------------------------------------*
*  -->  p1        text
*  <--  p2        text
*----------------------------------------------------------------------*
FORM frm_process_data .ENDFORM.

 

http://www.hskmm.com/?act=detail&tid=24

相关文章:

  • conda安装虚拟环境或者包时候都一个常见问题--HTTP 000 CONNECTION FAILED
  • 接口测试
  • 【IEEE出版】第四届传感器技术与控制国际研讨会(ISSTC 2025)
  • OCP、OMSP 和 OLP 是三种常见的光层保护机制的对比
  • 自从切到Qoder开发后,每天都心旷神怡
  • 电子烟的4种屏幕驱动集成语音方案介绍
  • Altair PSIM 2024下载地址与安装教程
  • 解构 MyEMS:开源能源管理系统的核心特性与价值图谱
  • 2025.9.9 树套树 + 分治 刷题日记
  • CF643E Bear and Destroying Subtrees
  • Go语言系统信息获取示例
  • OpenCSG 哈投达成战略合作,加速东北企业AI转型
  • Rocky9和Ubuntu使用pip安装python的库mysqlclient失败解决方式
  • 收录笔记:蜘蛛池,蜘蛛池出租 - 蚂蚁站群
  • 在Spring Boot Admin中根据Nacos的命名空间来区分和管理不同的环境
  • npm 无法加载文件npm.ps1
  • 蜘蛛池出租的使用效果 - 蚂蚁站群
  • REACT
  • 宽输入 低纹波 高效率 宽输入升降压型正负线性电源模块 BSN30WL
  • 【前端开发】windows激活自测可用,office也可激活
  • 核心漏洞开发实战:Win32漏洞挖掘与防护绕过深度解析
  • PostgreSQL 大对象管理指南:pg_largeobject 从原理到实践