首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Javascript:映射以创建子集数组

Javascript:映射以创建子集数组
EN

Stack Overflow用户
提问于 2021-02-20 13:55:34
回答 1查看 114关注 0票数 0

不是用来做实验的。我在这个网站上看过很多例子,但找不到一个适合我的……或者我应该说不能让它工作。

我有一个数组,当我运行console.log(Object.keys(MyArray)[0]);时,它返回0

当我运行console.log(Object.values(MyArray)[0]);返回时:

代码语言:javascript
复制
ARM1_ALARM: 1 
ARM1_APM_CH1_Mode: 11 
ARM1_APM_CH1_Setpoint: 110 
ARM1_APM_CH1_Temp: 111 
ARM1_Air1: 1 
ARM1_Air2: 0 
ARM1_Air3: 1 
ARM1_Air4: 1 
ARM1_CycleNumber: 1001 
ARM1_Fans1: 0 
ARM1_Fans2: 0 
ARM2_APM_CH1_Mode: 21 
ARM2_APM_CH1_Setpoint: 210 
ARM2_APM_CH1_Temp: 209 
ARM2_Air1: 1 
ARM2_Air2: 0 
ARM2_Air3: 0 
ARM2_Air4: 1 
ARM2_CycleNumber: 2001 
ARM2_Fans1: 1 
ARM2_Fans2: 0 
ARM3_APM_CH1_Mode: 21 
ARM3_APM_CH1_Setpoint: 310 
ARM3_APM_CH1_Temp: 310 
ARM3_Air1: 0 
ARM3_Air2: 0 
ARM3_Air3: 1 
ARM3_Air4: 1 
ARM3_CycleNumber: 3001 
ARM3_Fans1: 0 
ARM3_Fans2: 1 
ARM4_APM_CH1_Mode: 21 
ARM4_APM_CH1_Setpoint: 410 
ARM4_APM_CH1_Temp: 411 
ARM4_Air1: 1 
ARM4_Air2: 0 
ARM4_Air3: 0 
ARM4_Air4: 0 
ARM4_CycleNumber: 4001 
ARM4_Fans1: 0 
ARM4_Fans2: 0 

该数组最多可以有18000个对象,每个对象可以有150个关键点。我正在尝试从包含"ARM1“的主数组映射一个子集数组。尝试了map,filter,array.from,includes的许多组合...百无所成。

下面这行代码不起作用,但这也是我想要做的事情。任何帮助都将不胜感激!

代码语言:javascript
复制
var filteredarray = MyArray.map(function(d) {return Object.values(k => k.includes('ARM1'))});

根据@Jankapunkt的评论,以下是为我工作的修改后的代码:

代码语言:javascript
复制
const filteredarray = [MyArray].map(entries => {
  // this is the array of Objects within the greater array
  return entries.map(obj => {
    // build a custom object that only contains ARM1 keys
    const arm1 = {}
    Object.keys(obj).forEach(key => {
      if (key.includes('ARM1')) {
        arm1[key] = obj[key] // copy property
      }
    })
    return arm1
  })
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-02-20 17:13:34

数组的Object.keys将返回索引(0..n),因为这是数组在JavaScript中存储值(关联数组)的方式。

如果我做对了,你的数组包含对象,这就是过滤ARM1Object.keys很有价值的地方。

假设您的数组结构如下:

代码语言:javascript
复制
[
  [ { 'ARM1': 1, 'ARM3_FANS1': 0 }, ...],
  [ ... ],
  ...
]

你需要在这里迭代两次:

代码语言:javascript
复制
const filteredarray = MyArray.map(entries => {
  // this is the array of Objects within the greater array
  return entries.map(obj => {
    // build a custom object that only contains ARM1 keys
    const arm1 = {}
    Object.keys(obj).forEach(key => {
      if (key.includes('ARM1') {
        arm1[key] = obj[key] // copy property
      }
    })
    return arm1
  })
});

结果:

代码语言:javascript
复制
[
  [ { 'ARM1': 1 }, ...],
  [ ... ],
  ...
]

使用Array.flat或Array.flatMap来“扁平化”您的结构以满足您的需求。

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/66288482

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档