笔者参与的项目里,客户需要打印自己自定义格式的PO FORM。笔者在撰写PO FORM的功能说明书的时候,遇到了一个问题,在指定Payment Term的具体描述信息的取值方法的时候,破费了一些周折。笔者试图找到具体的表名和字段名,但是没能成功,后来找到了2个有用的function module, 问题解决。
如下采购订单,
该PO的payment term是0004,通过F1定位到如下配置界面:
MK01/XK01创建供应商主数据的时候,
0004这个付款条件的描述第一行是’payable immediately duenet’, 这个是有意义的,易于业务理解的描述。
如何通过程序取到描述’Payableimmediately Due net’ ? 从哪个表里取哪个字段?
该字段通过F1查,是结构R052-TXT02,
1)SE84去查这个结构字段的来源,查不到,
执行,
提示说是T052表的在线维护字段。
2)通过0004去T052/T052U里看,描述是空的,
3)通过0004去TVZBT里看,
有描述,但是只有‘asof end of month’,并不是我想要的描述。
4)花费很多时间查资料,没有找到合适的table。不过找到了一个function module FI_PRINT_ZTERM, se37 执行这个FM,
双击’2 Entries’前面的按钮,
得到了对于业务有用并且友好的描述信息了。
Pleasenote that although there is not a record in ABAP tablesTVZBT or T052U, the ABAP function module FI_PRINT_ZTERM is capable ofgenerating the payment term text using text symbols used in the program.
又查到了另外的一个Function Module: FI_TEXT_ZTERM,得到的结果貌似更好:
2017-10-13写于无锡市新吴区