首页 > 解决方案 > 如何检查 Json Doc 是否具有 Node JS 中的所有必需键

问题描述

我找到了多个关于如何检查 json 文件是否存在密钥的示例,但我正在尝试更有效地执行此操作。

我有一个导入过程,用户上传一个 csv 文件,然后我将其转换为 json。

由于在我的情况下 csv 文件有多种格式,我想在导入之前检查是否存在一组特定的字段/键,因为它们中的大多数具有不同的键名。

因此,首先我去计算 json 中的密钥计数,这缩小了我可能的定义。然后我想使用一个像这样的键数组

["field1", "field2", "field3"] 

然后检查它们是否都在我的json文件中。因为有一种简单的方法还是需要遍历数组并检查每个键?

标签: javascriptnode.jsjson

解决方案


您可以从 JSON 对象中提取键,但您仍然需要遍历“必需”键列表并检查它们是否存在于键列表中。像下面这样的东西应该可以解决问题:

const myObject = {}; // getObjectFromCSV();
const required = ["field1", "field2", "field3"];
const objKeys = Object.keys(myObject);
required.every(key => objKeys.includes(key));

要获取缺少的必填字段的列表,我会执行以下操作。此代码将替换上面的最后一行(使用every以下内容:

const missingRequired = required.reduce(
  (acc, key) => { 
    if (!objKeys.includes(key)) { 
      acc.push(key);
    } 
    return acc;
  }, []);
const isValid = missingRequired.length === 0;

在 reducer 函数中,acc是否将累加器设置为[]最初,如果它为空,则没有丢失键。请注意,与every函数相比,条件是相反的,因为我们想知道何时丢失了某个键,而不是是否找到了所有键。


推荐阅读