我不确定这是否可能,而且说实话,我没有尝试过很多东西,因为我不确定从哪里开始。我正在使用Google表格中的脚本编辑器,顺便说一句。我知道有SpreadsheetApp.getRange()和另一个获取值或类似的东西。但我想要的是有点具体。
有没有办法获取给定行中的所有单元格数据并将其放入数组中?行的大小会有所不同,这就是我无法做到确切范围的原因。
例如,如果我要让行具有以下值:
abc | 123 | 987 | efg
blah| cat | 654
我希望能够获取这些值并将它们放入像[“abc”,“123”,“987,”efg“]这样的数组中。然后,如果我在下一行运行该函数,它就会' d是[“blah”,“cat”,“654”]。
实际上,只要有能够使用的分隔符,它就可以放入任何数据类型。
提前谢谢!
答案 0 :(得分:3)
这对你有用吗?
当第1行,第2行和第3行,abc | 123 | 987 | efg
,blah| cat | 654
和abc | | 987 | efg
有myFunction(1)
,myFunction(2)
和myFunction(3)
时返回[abc, 123.0, 987.0, efg]
,[blah, cat, 654.0]
和[abc, , 987.0, efg]
。
function myFunction(row){
var ss = SpreadsheetApp.getActiveSheet();
var values = ss.getRange(row, 1, 1, ss.getLastColumn()).getValues();
var c = 0;
for (var c = values[0].length - 1; c >= 0; c--){
if (values[0][c] != "") break;
}
values[0].splice(c + 1, values[0].length - c - 1);
return values[0];
}
答案 1 :(得分:2)
改编自https://developers.google.com/apps-script/reference/spreadsheet/sheet#getDataRange()
如果你想要一个数组,你可以直接循环和创建你的数组。这里我将说明为所有行创建,但是如果你知道你想要的行,你可以不用外部循环(只需将i设置为所需的行)。
`function rowArr() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var sheet = ss.getSheets()[0];
// This represents ALL the rows
var range = sheet.getDataRange();
var values = range.getValues();
for (var i = 0; i < values.length; i++) {
var row = [];
for (var j = 0; j < values[i].length; j++) {
if (values[i][j]) {
row.push(values[i][j]);
}
}
Logger.log(row);
}
}`
答案 2 :(得分:1)
如果没有脚本,这更容易实现,公式=filter(1:1, len(1:1))
返回第1行中非空单元格中的所有值,等等。
从脚本中,您可以执行以下操作:
function flat_nonempty() {
var range = SpreadsheetApp.getActiveSheet().getRange("A:A"); // range here
var values = range.getValues();
var flat = values.reduce(function(acc, row) {
return acc.concat(row.filter(function(x) {
return x != "";
}));
}, []);
Logger.log(flat); // flat list of values, no blanks
}
此处的范围可以有一行或多行。