Javascript:映射创建子集数组
Javascript: Mapping to create a subset array
不要试验未 Javascript。我在该站点上查看了很多示例,但无法完全找到适合我的示例...或者我应该说它无法正常工作。
我有一个数组,当我 运行 console.log(Object.keys(MyArray)[0]);
returns 0
.
当我运行console.log(Object.values(MyArray)[0]);
returns:
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”的主数组映射子集数组。尝试了地图、过滤器、array.from、包括...的多种组合,但均未成功。
下一行不工作,但这是我正在努力工作的类似内容。如有任何帮助,我们将不胜感激!
var filteredarray = MyArray.map(function(d) {return Object.values(k => k.includes('ARM1'))});
根据@Jankapunkt 的评论,这是对我有用的修改后的代码:
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
})
});
Array 的 Object.keys
将 return 索引 (0..n) 因为这是 Arrays 在 JavaScript.
中存储值(关联数组)的方式
当我做对时,您的数组包含对象,这就是 Object.keys
对 ARM1
进行过滤的价值所在。
假设您的数组结构如下:
[
[ { 'ARM1': 1, 'ARM3_FANS1': 0 }, ...],
[ ... ],
...
]
这里需要迭代两次:
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
})
});
结果:
[
[ { 'ARM1': 1 }, ...],
[ ... ],
...
]
使用 Array.flat 或 Array.flatMap 以根据需要“扁平化”您的结构。
不要试验未 Javascript。我在该站点上查看了很多示例,但无法完全找到适合我的示例...或者我应该说它无法正常工作。
我有一个数组,当我 运行 console.log(Object.keys(MyArray)[0]);
returns 0
.
当我运行console.log(Object.values(MyArray)[0]);
returns:
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”的主数组映射子集数组。尝试了地图、过滤器、array.from、包括...的多种组合,但均未成功。
下一行不工作,但这是我正在努力工作的类似内容。如有任何帮助,我们将不胜感激!
var filteredarray = MyArray.map(function(d) {return Object.values(k => k.includes('ARM1'))});
根据@Jankapunkt 的评论,这是对我有用的修改后的代码:
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
})
});
Object.keys
将 return 索引 (0..n) 因为这是 Arrays 在 JavaScript.
当我做对时,您的数组包含对象,这就是 Object.keys
对 ARM1
进行过滤的价值所在。
假设您的数组结构如下:
[
[ { 'ARM1': 1, 'ARM3_FANS1': 0 }, ...],
[ ... ],
...
]
这里需要迭代两次:
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
})
});
结果:
[
[ { 'ARM1': 1 }, ...],
[ ... ],
...
]
使用 Array.flat 或 Array.flatMap 以根据需要“扁平化”您的结构。