微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

操作 ArrayNode 以用作 Groovy 中的 JsonBuilder 参数

如何解决操作 ArrayNode 以用作 Groovy 中的 JsonBuilder 参数

我正在尝试执行一个从服务器站点检索一组信息的编排,我想操作输出以便仅获取必要的数据。

输出的操作菜单,允许我通过 Groovy 编码来处理它。

未经操作的输出会抛出如下的 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 举报,一经查实,本站将立刻删除。