我正在尝试开发一个UDF(队列的所有值),它将字符串作为输入包含字段和字段值的管道(|)分隔符。此外,字符串同时包含 Header 和 Detail。
标题字段将在一行中出现一次,并在“N”次中出现详细信息。
下面是输入字符串::
Headerfield1|fieldValue1|Headerfield2|fieldValue2|Headerfield3|fieldValue3|Headerfield4|fieldValue4|Headerfield5|fieldValue5|Headerfield6|fieldValue6|Itemfield1|fieldvalue1|Itemfield1|fieldvalue1|Itemfield2|fieldvalue2|Itemfield3|fieldvalue3|Itemfield4|fieldvalue4|Itemfield1-1|fieldvalue1-1|Itemfield2-1|fieldvalue1-2|Itemfield3-1|fieldvalue3-1|Itemfield4-1|fieldvalue4-1|Itemfield1-2|fieldvalue1-2|Itemfield2-2|fieldvalue2-2|Itemfield3-2|fieldvalue3-2|Itemfield4-2|fieldvalue4-2|
在上面的字符串中,Headerfield1 是一个字段,其对应的值是 fieldValue1
在 UDF 中,我们在变量输入中传递输入字符串,在变量字段中传递必填字段。
我正在尝试传递字段名称并期望其相应的字段值作为输出
Below is the UDF
public void StringSplit(String[] input, String[] field, ResultList result, Container container) throws StreamTransformationException{
String str = input.toString();
String tokens[] = str.split("\\|");
Map<String, String>tokensMap = new HashMap();
int j =0;
for(int i =0; i <tokens.length ; i++)
{
if(j == i)
{
String key = tokens[i].toString();
if (key.contains("-"))
{
String key2 = key.substring(0, key.indexOf("-"));
if(tokensMap.containsKey(key2))
{
tokensMap.put(key2, tokensMap.get(key2)+","+tokens[i+1].toString());
}
else
{
tokensMap.put(key.substring(0, key.indexOf("-")),tokens[i+1].toString());
}
}
else
{
tokensMap.put(tokens[i].toString(),tokens[i+1].toString());
}
j = i+2;
}
}
String[] result1 = tokensMap.get(field).split(",");
for (int i = 0; i < result1.length; i++)
{
if (result1[i].equals("") || result1[i].equals(null) )
result.addSuppress();
else
result.addValue(result1[i]);
}
}
此 UDF 接受输入字符串并使用 pipe(|) 拆分并将其保存在令牌中,然后将其添加到 tokensMap。最后获取所需字段并存储到 result1 中,并使用 for 循环添加到结果列表中。我在下面收到错误。
错误
com.sap.xi.tf 类中的异常:[java.lang.ArrayIndexOutOfBoundsException:]。
附上错误日志屏幕截图。粉煤灰。
请检查错误并建议我需要更改的地方。
提前致谢
谢谢你,Chakradhar N!