如何解决操作 ArrayNode 以用作 Groovy 中的 JsonBuilder 参数
我正在尝试执行一个从服务器站点检索一组信息的编排,我想操作输出以便仅获取必要的数据。
未经操作的输出会抛出如下的 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"}]
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。