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

相关文章

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

电脑报错cxcore100.dll丢失怎么办? 多种免费修复缺失的cxcore100.dll文件的技巧

《电脑报错cxcore100.dll丢失怎么办?多种免费修复缺失的cxcore100.dll文件的技巧》你是否也遇到过“由于找不到cxcore100.dll,无法继续执行代码,重新安装程序可能会解... 当电脑报错“cxcore100.dll未找到”时,这通常意味着系统无法找到或加载这编程个必要的动态链接库

如何关闭 Mac 触发角功能或设置修饰键? mac电脑防止误触设置技巧

《如何关闭Mac触发角功能或设置修饰键?mac电脑防止误触设置技巧》从Windows换到iOS大半年来,触发角是我觉得值得吹爆的MacBook效率神器,成为一大说服理由,下面我们就来看看mac电... MAC 的「触发角」功能虽然提高了效率,但过于灵敏也让不少用户感到头疼。特别是在关键时刻,一不小心就可能触

Python批量调整Word文档中的字体、段落间距及格式

《Python批量调整Word文档中的字体、段落间距及格式》这篇文章主要为大家详细介绍了如何使用Python的docx库来批量处理Word文档,包括设置首行缩进、字体、字号、行间距、段落对齐方式等,需... 目录关键代码一级标题设置  正文设置完整代码运行结果最近关于批处理格式的问题我查了很多资料,但是都没

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

MySQL 日期时间格式化函数 DATE_FORMAT() 的使用示例详解

《MySQL日期时间格式化函数DATE_FORMAT()的使用示例详解》`DATE_FORMAT()`是MySQL中用于格式化日期时间的函数,本文详细介绍了其语法、格式化字符串的含义以及常见日期... 目录一、DATE_FORMAT()语法二、格式化字符串详解三、常见日期时间格式组合四、业务场景五、总结一、

mysql线上查询之前要性能调优的技巧及示例

《mysql线上查询之前要性能调优的技巧及示例》文章介绍了查询优化的几种方法,包括使用索引、避免不必要的列和行、有效的JOIN策略、子查询和派生表的优化、查询提示和优化器提示等,这些方法可以帮助提高数... 目录避免不必要的列和行使用有效的JOIN策略使用子查询和派生表时要小心使用查询提示和优化器提示其他常

Apache伪静态(Rewrite).htaccess文件详解与配置技巧

《Apache伪静态(Rewrite).htaccess文件详解与配置技巧》Apache伪静态(Rewrite).htaccess是一个纯文本文件,它里面存放着Apache服务器配置相关的指令,主要的... 一、.htAccess的基本作用.htaccess是一个纯文本文件,它里面存放着Apache服务器