JAVA UDF-用于SAP PI中相同上下文的并置

2020-08-14 18:21发布

点击此处---> 群内免费提供SAP练习系统(在群公告中)加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)专家们, 从下面的屏幕截图-它...

         点击此处--->   EasySAP.com群内免费提供SAP练习系统(在群公告中)

加入QQ群:457200227(SAP S4 HANA技术交流) 群内免费提供SAP练习系统(在群公告中)


专家们,

从下面的屏幕截图-它的一对一映射-但是,我们需要将显示队列中的值连接起来,并处理为以逗号分隔的目标文件-在下面的示例中

输出:

10MG,20MG,40MG,50 MG等...

您能提供JAVA udf的帮助吗?

此致

concatanate.jpg (21.9 kB)
付费偷看设置
发送
6条回答
宇峰Kouji
1楼-- · 2020-08-14 18:32

你好 SAKRIYANAIK NK

您可以使用以下UDF在每个上下文后添加逗号。

public void addComma(String [] personNum,ResultList结果,Container容器)抛出StreamTransformationException {

String target ="";

for(int i = 0; i

{

target = target + personNum [i];

如果(i!= personNum.length-1)

{

//如果我不等于personNum.length -1

target = target +",";

}

result.addValue(target);

}

谢谢

Rajesh PS

SAP小菜
2楼-- · 2020-08-14 18:27

Goog。 是的,您可以获得上下文的最后一个值。

//获取上下文的最后一个值

int x;

字符串y ="";

x = personNumber.length;

y = personNumber [x-1];

result.addValue(y);

谢谢!

三十六小时_GS
3楼-- · 2020-08-14 18:32

嗨Rajesh,

这有效-我们在下面得到的输出中的代码有少量更改。

10,

10,20,

10,20,30,

10,20,30,40,依此类推。

----

在上述情况下-我们需要处理最后一行,即10、20、30、40,依此类推,以此类推。

-----

落灬小鱼
4楼-- · 2020-08-14 18:33

您好 SAKRIYANAIK

< p> Rajesh 的代码可以很好地工作。 只需对输入字段使用删除上下文作为输入字段(String [] personNum) 在映射中调用UDF之前。

注意

Anupam

Baoming ROSE
5楼-- · 2020-08-14 18:37

嗨Rajesh,

感谢您的及时答复。 这里的场景几乎没有什么不同。 我们正在获取多个订单项中的值,如果您查看以下队列值。

在输出中-我们只需要在目标字段中写入最后一个值10、20、40。

代楠1984
6楼-- · 2020-08-14 18:46

非常简单的代码...具有队列上下文

int i = ProductID.length;

result.addValue(ProductID [i-1]);

工作正常,谢谢。

一周热门 更多>