1

如何在 Google 表格的一组单元格中创建一组值?

该数组应与单元格具有相同的行和列,并且应与工作表在每个位置的值相同。

另外,我希望能够将数组的范围作为参数传递,以便我可以将该函数用于不同的范围。

编辑2:新代码,几乎可以工作,我只需要让它接收来自谷歌工作表本身的用户输入的范围。这就是我想要的工作,但一开始是努力工作,我无法选择范围并让单元格更新并让函数运行。

此外,我几乎每次都遇到参考错误的问题,即使我尝试在没有任何参数的情况下预设函数内的范围

function sortingtest(pWO, pInfo, pSearch) {
    var WO = SpreadsheetApp.getActiveSpreadsheet().getRange(pWO).getValues();
    var Info = SpreadsheetApp.getActiveSpreadsheet().getRange(pInfo).getValues();
    var Search = SpreadsheetApp.getActiveSpreadsheet().getRange(pSearch).getValues();
    //[row][column]

    var FinalArray1 = [];
    var FinalArray2 = [];
    var FinalArray3 = [];
    var LastArray = [];
    var a = 0;
    var b = 0;
    var c = 0;
    var d = 0;

    for (var row = 0; row < WO.length; row ++) {
        var counter = row - 1;
        while (WO[row] == "") {
            WO[row] = WO[counter];
            counter--;
        }
    }

    for (var col = 0; col < Info[0].length; col++) {
        for (var row = 0; row < Info.length; row++) {
            if (Info[row][col] == Search[col]) {
                if (col == 0) {
                    FinalArray1[a] = WO[row];
                    a++;
                }
                else if (col == 1) {
                    FinalArray2[b] = WO[row];
                    b++;
                }
                else if (col == 2) {
                    FinalArray3[c] = WO[row];
                    c++;
                }
            }
        }
    }

    for (var i = 0; i < FinalArray1.length; i++) {
        for (var j = 0; j < FinalArray2.length; j++) {
            for (var k = 0; k < FinalArray3.length; k++) {
                if (FinalArray3[k] == FinalArray2[j] && FinalArray2[j] == FinalArray1[i]) {
                    LastArray[d] = FinalArray1[i];
                    d++;
                }
            }
        }
    }
    return LastArray;
}
4

1 回答 1

1

如果您按照注释 ( =sortingtest(sheet1!A1:C12,sheet3!D1:E12,sheet2!F1:G4)) 中的说明从电子表格中调用函数,则无需调用任何 SpreadsheetApp 函数来获取数组:pWOpInfo并且pSearch已经是二维数组。

引用谷歌自定义函数文章

如果您使用对单元格范围的引用作为参数调用您的函数(like =DOUBLE(A1:B10)),则该参数将是单元格值的二维数组。例如,在下面的屏幕截图中,=DOUBLE(A1:B2)Apps 脚本将 中的参数解释为double([[1,3],[2,4]]).

于 2015-06-18T14:15:12.063 回答