google-apps-script - 最后一个元素不包含在数组中的映射变量中
问题描述
通过映射从数组中获取值存在问题。
这里有两个模块。模块 globalVars 中的脚本运行良好,它正在获取全局变量和数组。
const url = SpreadsheetApp.getActiveSpreadsheet().getUrl();
let ss = SpreadsheetApp.openByUrl(url);
let shSISTEM = ss.getSheetByName("@sistem");
// SETTINGS LIST NAMES ->>>>>>>>>>>>>>>>>>>>>>>>
const rngSISNMS = [
'RTSout',
'CAFin',
'CAFout',
'RTSin',
'NameJSONS',
'NameTable',
];
/////////////////////////////////////////////
// ARRAYS OF SISTEM TABLES
let [arrRTSout, arrCAFin, arrCAFout, arrRTSin, arrJSONS] = rngSISNMS.map(rangeName => {
return shSISTEM.getRange(rangeName).getDataRegion().getValues();
});
问题出在具有函数 jobForWork 的模块 impJSONS 中。我有这个脚本:
function jobForWork(){
// Iamblichus code
// const [nameJSON, turnON, nameTABLE, nameARR, nameDIR, idDIR] = arrJSONS[0].map((_, colIndex) => arrJSONS.map(row => row[colIndex]));
// my code
for (var i = 0; i < arrJSONS.length; i ++){
var j = 0;
let [nameJSON, turnON, nameTABLE, nameARR, nameDIR, idDIR] = arrJSONS.map(() => {
Logger.log(`element ${j}: ${arrJSONS[i][j]}`);
let vOut = arrJSONS[i][j];
j++;
return vOut;
});
/// some opeartions with variables of i-elements in arrJSONS
// ....outside functions with each i-elements
if (nameJSON == "jobToRTS") start(nameDIR, idDIR);
if (nameDIR == "IN_CAF") next(nameTABLE, nameARR);
if (turnON) finish(nameJSON);
/// ...
}
}
该脚本适用于“T:Y”中表中的数组 arrJSONS。它通过 arrJSONS.map 将数组中的元素放入变量中,但它在元素 j = 4 处停止,仅此而已。所以数组的最后一个元素不包含在变量 idDIR 中。你能帮助我吗?
解决方案
如果您只想迭代,arrJSONS
并且对于每次迭代,您想将内部数组中的每个单个值存储在不同的变量中,数组解构就足够了,您不需要map
:
function jobForWork(){
for (var i = 0; i < arrJSONS.length; i ++) {
let [nameJSON, turnON, nameTABLE, nameARR, nameDIR, idDIR] = arrJSONS[i];
// Do whatever you want with these variables
}
}
推荐阅读
- mysql - MySQL 查询优化与大型数据库上的子查询和 JOIN
- facebook - 如何将 Instagram 贴纸导入 spark ar?
- javascript - 无法在 heroku 服务器上获取/注册错误
- mysql - SQL查询,根据行是否存在选择顶部结果或底部结果
- python - 无法在 Python 中使用我的类实例进行多处理
- arduino - 一个文本中有 2 个变量和 1 个字符串
- flutter - 颤振:从颤振应用程序构建apk失败
- scala - 异常在 scala shell 中被截断
- r - graphviz / DiagrammeR - 子图从上到下,然后从左到右
- amazon-web-services - AWS CodePipeline 无法将 EFS 附加到多容器 Docker Elastic Beanstalk