SAP小技巧 调整IDOC的过账日期

2023-10-14 02:10

本文主要是介绍SAP小技巧 调整IDOC的过账日期,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

点击蓝字 关注我们

前言

IDOC是ECC/S4系统中的一种接口数据整合形式.前文已经介绍了关于IDOC的部分知识.

详见连接

无峰,公众号:ABAP 技巧与实战SAP操作手册之 IDOC基础篇

详见链接

无峰,公众号:ABAP 技巧与实战SAP操作手册之 IDOC开发篇

当我们在入站接口的场景中使用IDOC的时候,可能会面临一个问题: 产生IDOC的时候已经把记账日期写入. 如果IDOC过账的时候,IDOC中的过账日期对应的账期关闭.IDOC过账会报错.(图一是一个创建商品凭证的IDOC因为账期关闭报错)

本文主要介绍解决IDOC由于过账日期报错的几种方式,并着重介绍过账前检查账期并调整过账日期的增强

一般创建商品凭证的IDOC有这个需求.

67eff85d0656179517d8ee82e53a96f5.png

图一

01

关于物料账期

物料账期是SAP的一个重要概念.

通过事务代码MMPV可以打开指定公司代码的新的账期. 

物料账期只能打开两个月的. 

可以通过事务代码MMRV修改前期记账标记控制是否能够记账在上期.

物料账期对应的表 MARV

ab66feff7937649802ac43dfed009adf.png

解决账期报错的方式

解决IDOC账期报错有几种方式

  • 通过WE02的编辑功能修改IDOC中的过账日期

  • 通过ZIFIDOC接口监控批量修改IDOC中的过账日期

  • 通过增强在IDOC过账的时候修改传入BAPI函数的过账日期

WE02修改IDOC

旧版本的ECC中事务代码WE02可能无法修改IDOC内容. 需要使用事务代码: WE05 

新版本ECC或S4中WE02等同于WE05 .均可修改IDOC内容(包含控制内容与数据内容)

通过标准功能修改IDOC中的过账日期字段内容

详细操作步骤在前文有介绍,这里不再赘述.

详见链接

无峰,公众号:ABAP 技巧与实战SAP操作手册之 IDOC监控-标准功能

ZIFIDOC修改IDOC

通过WE02修改IDOC的内容操作步骤比较繁琐.每次只能操作一个IDOC的修改. 

如果有很多报错的IDOC. WE02修改会把人折磨致死. 所以当初设计IDOC集中监控程序: ZIFIDOC时, 在里面添加了一个批量修改IDOC内容的功能.

更多ZIFIDOC功能介绍详见链接

无峰,公众号:ABAP 技巧与实战SAP工具箱之 IDOC监控-增强功能

01

配置 ZTSEGNAM

因为IDOC结构复杂,层级很多.如果要通过表格显示,只能关注一个抬头段.一个明细段. 配置表ZTSEGNAM用来指定每个消息类型用于表格呈现的抬头段与明细段

d75ced8adf7110e093af951fd6862112.png

02

进入监控程序

进入IDOC监控程序,显示需要修改的IDOC. 勾选需要修改的IDOC(允许相同类型的多个IDOC同时勾选), 点击显示错误原因和消息内容进入IDOC内容呈现

5025a3bf16c6d1aac880a3f63d84563b.png

03

启用修改模式

在IDOC内容呈现中点击编辑功能会激活IDOC的修改, 修改后点击保存按钮会把修改的内容保存到IDOC中.

c925002ea64856d4800dc38ff1628523.png

4e3d677f6d04a8b44533b0c8b69f00e1.png

通过增强调整过账日期

上面两个方案都需要针对特定的IDOC调整账期字段.如果希望这些账期关闭的IDOC能自动过账到当前日期. 则可以通过如下的增强实现.

自动调整账期由接口控制表字段ZTIF002-ZQKTZ控制特定接口编号是否启用. 并通过配置表ZTIDOC_BUDAT控制消息类型是否启用.

01

配置表

为了让过账日期自动调整的增强适用于更多的场景,设计了一个配置表. ZTIDOC_BUDAT.用于配置需要调整账期的IDOC类型及IDOC中识别日期,地点,公司代码的段名和字段名

1f1e7aa7361de7df3c4d51c25ce43617.png

02

重要字段说明

检查原过账日期所在账期是否打开

40cc61153abbd71e2fdf8e61cc4d4a0e.png

账期调整方式

435fdd2ac8acafafb6a673a1148bb1bc.png

03

配置实例

1a6bf5490b1effce60c3f1702dd1c39d.png

04

增强位置

该增强写在标准函数 BAPI_IDOC_INPUT1 开头的隐式增强中. 

这个函数会处理所有产生一个单据的BAPI调用类的IDOC. 具有一定的通用性.

7bdff242a43098a6d546ea5c36479d85.png

05

增强逻辑

  • 根据配置表内容读取过账日期,读取地点或公司代码.

  • 检查过账日期所在的月是否已经关闭物料账期

  • 如果关闭,根据配置设置新的过账日期

06

封装函数

封装函数Z_IDOC_GET_SET_DATA用于读取或者设置IDOC中指定段名和字段名的字段内容

7dca42d61a2f40e8152f6cea7387bfdf.png

总结

通过上述本文介绍的方式可以手动/批量的修改IDOC中的过账日期,过账到新开的账期,避免因为账期关闭而报错.

增强调整过账日期在IDOC调用BAPI产生商品凭证时,调整传入BAPI的过账日期.也可以避免账期关闭而报错. 这样会导致IDOC产生的凭证中的过账日期不等于IDOC中的过账日期. 但是无需用户费力调整IDOC内容.

THE

END

约定

如果你对这篇文章感兴趣,请帮忙点赞,在看,分享.       

    (如果你真的喜欢这篇文章,请记得回来打个赏,作为支持我继续下去的动力,这是一个正反馈过程. 越多的人打赏,作者越有动力分享,读者就能享受更多的福利.毕竟打赏的金额富不了我,穷不了你,却能支持这个公众号长久发文.)

0f9ced1fbb3ad702d94b2abfa6b33450.png

公众号 : syjf1976_abap

          ABAP开发技巧

微信号 : 392077

请微信联系管理员: 

syjf1976 

sharry_xlp  

Yannick_Duan 

申请进入公众号讨论群提问或者参与话题讨论

这篇关于SAP小技巧 调整IDOC的过账日期的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/207426

相关文章

Java实现复杂查询优化的7个技巧小结

《Java实现复杂查询优化的7个技巧小结》在Java项目中,复杂查询是开发者面临的“硬骨头”,本文将通过7个实战技巧,结合代码示例和性能对比,手把手教你如何让复杂查询变得优雅,大家可以根据需求进行选择... 目录一、复杂查询的痛点:为何你的代码“又臭又长”1.1冗余变量与中间状态1.2重复查询与性能陷阱1.

Python内存优化的实战技巧分享

《Python内存优化的实战技巧分享》Python作为一门解释型语言,虽然在开发效率上有着显著优势,但在执行效率方面往往被诟病,然而,通过合理的内存优化策略,我们可以让Python程序的运行速度提升3... 目录前言python内存管理机制引用计数机制垃圾回收机制内存泄漏的常见原因1. 循环引用2. 全局变

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

Python进阶之列表推导式的10个核心技巧

《Python进阶之列表推导式的10个核心技巧》在Python编程中,列表推导式(ListComprehension)是提升代码效率的瑞士军刀,本文将通过真实场景案例,揭示列表推导式的进阶用法,希望对... 目录一、基础语法重构:理解推导式的底层逻辑二、嵌套循环:破解多维数据处理难题三、条件表达式:实现分支

Python中的filter() 函数的工作原理及应用技巧

《Python中的filter()函数的工作原理及应用技巧》Python的filter()函数用于筛选序列元素,返回迭代器,适合函数式编程,相比列表推导式,内存更优,尤其适用于大数据集,结合lamb... 目录前言一、基本概念基本语法二、使用方式1. 使用 lambda 函数2. 使用普通函数3. 使用 N

Go语言网络故障诊断与调试技巧

《Go语言网络故障诊断与调试技巧》在分布式系统和微服务架构的浪潮中,网络编程成为系统性能和可靠性的核心支柱,从高并发的API服务到实时通信应用,网络的稳定性直接影响用户体验,本文面向熟悉Go基本语法和... 目录1. 引言2. Go 语言网络编程的优势与特色2.1 简洁高效的标准库2.2 强大的并发模型2.

Python 函数详解:从基础语法到高级使用技巧

《Python函数详解:从基础语法到高级使用技巧》本文基于实例代码,全面讲解Python函数的定义、参数传递、变量作用域及类型标注等知识点,帮助初学者快速掌握函数的使用技巧,感兴趣的朋友跟随小编一起... 目录一、函数的基本概念与作用二、函数的定义与调用1. 无参函数2. 带参函数3. 带返回值的函数4.

Python标准库datetime模块日期和时间数据类型解读

《Python标准库datetime模块日期和时间数据类型解读》文章介绍Python中datetime模块的date、time、datetime类,用于处理日期、时间及日期时间结合体,通过属性获取时间... 目录Datetime常用类日期date类型使用时间 time 类型使用日期和时间的结合体–日期时间(

游戏闪退弹窗提示找不到storm.dll文件怎么办? Stormdll文件损坏修复技巧

《游戏闪退弹窗提示找不到storm.dll文件怎么办?Stormdll文件损坏修复技巧》DLL文件丢失或损坏会导致软件无法正常运行,例如我们在电脑上运行软件或游戏时会得到以下提示:storm.dll... 很多玩家在打开游戏时,突然弹出“找不到storm.dll文件”的提示框,随后游戏直接闪退,这通常是由于

MySQL 多列 IN 查询之语法、性能与实战技巧(最新整理)

《MySQL多列IN查询之语法、性能与实战技巧(最新整理)》本文详解MySQL多列IN查询,对比传统OR写法,强调其简洁高效,适合批量匹配复合键,通过联合索引、分批次优化提升性能,兼容多种数据库... 目录一、基础语法:多列 IN 的两种写法1. 直接值列表2. 子查询二、对比传统 OR 的写法三、性能分析