gpt4 book ai didi

javascript - 从对象数组动态构建二维数组

转载 作者:行者123 更新时间:2023-12-01 00:23:14 24 4
gpt4 key购买 nike

我正在 Google 脚本中使用以下函数

function writeToSheet(sheet, data, dataName, dataPts) {
var rows = [];

Logger.log(dataPts);
for (var z = 0; z < data.length; z++) {
var subRow = [];
for (var q = 0; q < dataPts.length; q++) {
subRow.push(dataName[z][dataPts[q]])
}
rows.push(subRow);
subRow = [];
}
Logger.log(rows);
dataRange = sheet.getRange(sheet.getLastRow()+1, 1, rows.length, rows[0].length);
dataRange.setValues(rows);
}

我向函数传递了一个要写入的工作表,数据是一个对象数组,dataName 是我用来尝试从原始数组中提取数据的 dataName,dataPts 是我要写入的属性名称的数组。想要从原始数组中的每个对象中提取并作为数组嵌套在完成的数组中 -

无论我如何尝试完成这项工作,我最终都会得到字符串的数组构建,如果将其硬编码到函数中,它将准确地给出我想要的内容。但是,我无法弄清楚如何动态地执行此操作,以便它适用于我提供的任何数据。

有人有什么想法吗?我考虑过尝试过滤掉原始数组中每个对象的属性,然后以某种方式将剩余键中的值转换为每个对象的数组,但我不知道如何执行此操作或是否可能。

感谢任何人可能提出的任何建议:)

最佳答案

所以我设法让它工作。

function writeToSheet(sheet, data, dataPts) {
var rows = [];
var data = data;

Logger.log(dataPts);
for (var z = 0; z < data.length; z++) {
var subRow = [];
for (var q = 0; q < dataPts.length; q++) {
subRow.push(data[z][dataPts[q]])
}
rows.push(subRow);
subRow = [];
}
Logger.log(rows);
dataRange = sheet.getRange(sheet.getLastRow()+1, 1, rows.length, rows[0].length);
dataRange.setValues(rows);
}

我意识到 dataName 变量是不必要的,导致我的函数将此行视为字符串,而不是从嵌套对象中提取相关值:

subRow.push(data[z][dataPts[q]])

关于javascript - 从对象数组动态构建二维数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59233693/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com