【问题标题】:Postman - How to get the value from a JSON response for the last occurrence of the required attributesPostman - 如何从 JSON 响应中获取最后一次出现所需属性的值
【发布时间】:2019-04-02 18:06:56
【问题描述】:

我是 JSON 和 Postman 的新手。我相信我正在尝试做一些非常简单的事情。

我创建了一个 GET 请求,它将获得如下所示的 JSON 响应。

在下面的示例中,我想获取最后一个“IsArchived”属性的值(“版本”之前的那个);或者不属于 FieldGroup 的那个。

我该怎么做? (尽管可能会通过回答我的其他问题来回答)提前谢谢

{
    "Id": 1328,
    "Name": "AAA Test",
    "Owner": {
        "Id": 208,
        "Name": "The Boss"
    },
    "FieldGroups": [
        {
            "Id": "c81376f0-6ac3-4028-8d61-76a0f815dbf8",
            "Name": "General",
            "FieldDefinitions": [
                {
                    "Id": 1,
                    "DisplayName": "Product Name",
                    "IsArchived": false
                },
                {
                    "Id": 2,
                    "DisplayName": "Short Description",
                    "IsArchived": false
                },
                {
                    "Id": 33,
                    "DisplayName": "Long Description",
                    "IsArchived": false
                },
            ]
        },
        {
            "Id": "5ed8746b-0fa8-4022-8216-ad3af17db91f",
            "Name": "Somethingelse",
            "FieldDefinitions": [
                {
                    "Id": 123,
                     "DisplayName": "Attribution",
                    "IsArchived": false
                },
                {
                    "Id": 1584,
                    "DisplayName": "FC1",
                    "IsArchived": false
                },
                {
                    "Id": 623,
                    "DisplayName": "Sizes",
                    "IsArchived": false,
                    "Owner": {
                        "Id": 208,
                        "Name": "The Boss"
                    },
                    "Unit": "",
                    "Options": [
                        {
                            "Id": 1,
                            "Value": "XS"
                        },
                        {
                            "Id": 2,
                            "Value": "S"
                        },
                        {
                            "Id": 3,
                            "Value": "M"
                        },
                    ]
                }
             ]
        }
    ],
    },
    "IsArchived": false
    "Version": 1
}

【问题讨论】:

标签: json postman


【解决方案1】:

这应该很容易,因为您的 IsArchived 属性位于 JSON 响应的顶层,因此除非您以某种方式循环遍历您的 FieldGroups 数组,否则不会使用另一个 IsArchived 值其他问题。

// Convert the response body to a JSON object
var jsonData = pm.response.json()

// Create a variable and assign the value of IsArchived to it
var isArchived = jsonData.IsArchived;

// OR create a Postman environment variable and assign the value of IsArchived to it
pm.environment.set("isArchived", jsonData.IsArchived);

【讨论】:

    【解决方案2】:

    首先,您处理的 JSON 无效。您可以随时使用JSONLint 检查您的 JSON 有效性。

    这是有效的 JSON:

    {
        "Id": 1328,
        "Name": "AAA Test",
        "Owner": {
            "Id": 208,
            "Name": "The Boss"
        },
        "FieldGroups": [{
                "Id": "c81376f0-6ac3-4028-8d61-76a0f815dbf8",
                "Name": "General",
                "FieldDefinitions": [{
                        "Id": 1,
                        "DisplayName": "Product Name",
                        "IsArchived": false
                    },
                    {
                        "Id": 2,
                        "DisplayName": "Short Description",
                        "IsArchived": false
                    },
                    {
                        "Id": 33,
                        "DisplayName": "Long Description",
                        "IsArchived": false
                    }
                ]
            },
            {
                "Id": "5ed8746b-0fa8-4022-8216-ad3af17db91f",
                "Name": "Somethingelse",
                "FieldDefinitions": [{
                        "Id": 123,
                        "DisplayName": "Attribution",
                        "IsArchived": false
                    },
                    {
                        "Id": 1584,
                        "DisplayName": "FC1",
                        "IsArchived": false
                    },
                    {
                        "Id": 623,
                        "DisplayName": "Sizes",
                        "IsArchived": false,
                        "Owner": {
                            "Id": 208,
                            "Name": "The Boss"
                        },
                        "Unit": "",
                        "Options": [{
                                "Id": 1,
                                "Value": "XS"
                            },
                            {
                                "Id": 2,
                                "Value": "S"
                            },
                            {
                                "Id": 3,
                                "Value": "M"
                            }
                        ]
                    }
                ]
            }
        ],
        "IsArchived": false,
        "Version": 1
    }
    

    现在我假设你想在 Postman 测试中获取属性,你可以在这里实现:

    var responseData = pm.response.json();
    var isArchived = responseData.isArchived;
    

    【讨论】:

    • 谢谢 div。您的答案有效,只需要使用“.IsArchived”而不是“.isArchived”。
    • 顺便说一句,为什么我的 json 无效?我看不出你和我的区别。
    • @KVN: 复制你的 JSON,转到 jsonlint.com 粘贴到那里并点击验证按钮,他们会告诉你出了什么问题
    • @KVN 您有一些 , 不需要它们:在数组中的最后一个对象之后。
    • 啊,明白了。谢谢迪夫!
    猜你喜欢
    • 2019-02-23
    • 1970-01-01
    • 2021-02-15
    • 1970-01-01
    • 1970-01-01
    • 2022-08-24
    • 1970-01-01
    • 2018-05-18
    • 2020-06-07
    相关资源
    最近更新 更多