问题描述
我正在尝试执行一个从服务器站点检索一组信息的编排,我想操作输出以便仅获取必要的数据。
未经操作的输出会抛出如下的 JSON:
{
"formId": "P43081_W43081A","gridId": "1","title": "Work With Orders Awaiting Approval","rowset": [
{
"P43081_AN8_Originator": "304565","P43081_DL01_supplier": "I.T. Laptop/Tablets","P43081_AN8_supplier": "533104",},{
"P43081_AN8_Originator": "304565","P43081_DL01_supplier": "Office Plus Supplies","P43081_AN8_supplier": "533103",}
],"records": 3,"moreRecords": false
}
我只需要行集级别的信息。为了做到这一点,我操作了包括以下代码的输出:
import groovy.json.JsonSlurper;
import groovy.json.JsonBuilder;
import com.oracle.e1.common.orchestrationAttributes;
String main(orchestrationAttributes orchAttr,String input)
{
def jsonIn = new JsonSlurper().parseText(input);
// modify jsonIn;
def jsonOut = new JsonBuilder(jsonIn.rowset);
// orchAttr.writeWarn("custom log entry - warning");
// orchAttr.writeDebug("custom log entry - debug");
return jsonOut;
}
这给我带来了以下错误:
"message": "com.fasterxml.jackson.databind.node.ArrayNode 不能 转换为 com.fasterxml.jackson.databind.node.ObjectNode"
我推断错误原因是因为我将 Array 对象(行集)而不是对象作为 JsonBuilder 参数传递。
您知道如何处理输出并将正确格式的参数传递给 JsonBuilder 吗?
我想得到的输出是:
{
"P43081_AN8_Originator": "304565",{
"P43081_AN8_Originator": "304565",}
解决方法
您可以改用 JsonOutput
。例如
import groovy.json.*
def data = new JsonSlurper().parse("data.json" as File)
println(JsonOutput.toJson(data.rowset));
// ⇒ [{"P43081_AN8_Originator":"304565","P43081_DL01_Supplier":"I.T. Laptop/Tablets","P43081_AN8_Supplier":"533104"},{"P43081_AN8_Originator":"304565","P43081_DL01_Supplier":"Office Plus Supplies","P43081_AN8_Supplier":"533103"}]