javascript - Postman - 如何计算 JSON 响应中特定对象的出现次数

标签 javascript json postman

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

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

在下面的示例中,我想获取响应中所有“IsArchived”属性的计数

这些属性的数量因响应而异。

我该怎么做?提前致谢

{
    "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
}

最佳答案

这是一个相当具体的解决方案,但我希望它能有所帮助。描述被添加为评论:

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

// Create a count variable which will be increased by 1 everytime IsArchived occurs
var count = 0;

function countIsArchived() {
    // Loop through the FieldGroupsArray
    _.each(jsonData.FieldGroups, (fieldGroupsArray) => {
        // Loop through the FieldDefinitionsArray
        _.each(fieldGroupsArray.FieldDefinitions, (fieldDefinitionsArray) => {
            // Check if IsArchived exists
            if(fieldDefinitionsArray.IsArchived) {
                // Increase count by 1
                count++;
            }
        });
    });

    // IF you want it:
    // Check if IsArchived exists on the top level of the JSON response and increase count
    if(jsonData.IsArchived) {
        count++;
    }
    // IF you want it:
    // Create a Postman environment variable and assign the value of count to it
    pm.environment.set("count", count);
}

附加信息:

后面的对象后面的,是不需要的。它使 JSON 无效:

{
    "Id": 33,
    "DisplayName": "Long Description",
    "IsArchived": false
},  <--

关于javascript - Postman - 如何计算 JSON 响应中特定对象的出现次数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55463615/

相关文章:

javascript - 从 react 中映射的选择输入中获取选定的值

rest - 集成到 Bit.ly API 版本 4 - 如何生成 OAuth2 token 以与 Bit.ly API V4 集成并创建缩短的 url?

javascript - 计算对象函数中另一个对象属性的长度 - JavaScript?

javascript - #ember-power-select : changing the value in one power-select box , 它交替更改另一个电源选择框的相同值

android - Android App中Google Maps API的JSON解析

azure - 微软地址验证API

api - 如何在 postman 中输入x-auth header ?

javascript - 使用 Math.max 和 Math.min 从数组中删除最大和最小数字

javascript - Quill Link 工具提示默认不可见

json - 使用云函数时,来自 firestore 的时间戳被转换为 Map