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

相关文章

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java实现优雅日期处理的方案详解

《Java实现优雅日期处理的方案详解》在我们的日常工作中,需要经常处理各种格式,各种类似的的日期或者时间,下面我们就来看看如何使用java处理这样的日期问题吧,感兴趣的小伙伴可以跟随小编一起学习一下... 目录前言一、日期的坑1.1 日期格式化陷阱1.2 时区转换二、优雅方案的进阶之路2.1 线程安全重构2

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Java Optional的使用技巧与最佳实践

《JavaOptional的使用技巧与最佳实践》在Java中,Optional是用于优雅处理null的容器类,其核心目标是显式提醒开发者处理空值场景,避免NullPointerExce... 目录一、Optional 的核心用途二、使用技巧与最佳实践三、常见误区与反模式四、替代方案与扩展五、总结在 Java

Mysql表如何按照日期字段的年月分区

《Mysql表如何按照日期字段的年月分区》:本文主要介绍Mysql表如何按照日期字段的年月分区的实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、创键表时直接设置分区二、已有表分区1、分区的前置条件2、分区操作三、验证四、注意总结一、创键表时直接设置分区

Python通过模块化开发优化代码的技巧分享

《Python通过模块化开发优化代码的技巧分享》模块化开发就是把代码拆成一个个“零件”,该封装封装,该拆分拆分,下面小编就来和大家简单聊聊python如何用模块化开发进行代码优化吧... 目录什么是模块化开发如何拆分代码改进版:拆分成模块让模块更强大:使用 __init__.py你一定会遇到的问题模www.

MyBatis 动态 SQL 优化之标签的实战与技巧(常见用法)

《MyBatis动态SQL优化之标签的实战与技巧(常见用法)》本文通过详细的示例和实际应用场景,介绍了如何有效利用这些标签来优化MyBatis配置,提升开发效率,确保SQL的高效执行和安全性,感... 目录动态SQL详解一、动态SQL的核心概念1.1 什么是动态SQL?1.2 动态SQL的优点1.3 动态S

Python使用date模块进行日期处理的终极指南

《Python使用date模块进行日期处理的终极指南》在处理与时间相关的数据时,Python的date模块是开发者最趁手的工具之一,本文将用通俗的语言,结合真实案例,带您掌握date模块的六大核心功能... 目录引言一、date模块的核心功能1.1 日期表示1.2 日期计算1.3 日期比较二、六大常用方法详

电脑win32spl.dll文件丢失咋办? win32spl.dll丢失无法连接打印机修复技巧

《电脑win32spl.dll文件丢失咋办?win32spl.dll丢失无法连接打印机修复技巧》电脑突然提示win32spl.dll文件丢失,打印机死活连不上,今天就来给大家详细讲解一下这个问题的解... 不知道大家在使用电脑的时候是否遇到过关于win32spl.dll文件丢失的问题,win32spl.dl