我创建了一个 Google 表格,其中包含基于 this tutorial 的相关下拉列表。 Copy of the sheet I've created. 我对依赖下拉列表的功能很满意,但是我的目标是从“材料”表(B:I 列)中复制一行中的所有数据,这些数据对应于从“crop_specific”表的 E 列中的相关下拉列表,将此信息复制到 E:L 列。我想保留当前脚本的功能,如果 D 列中的选择发生更改,则清除 E 列中的内容,并将其扩展到整行。任何帮助将非常感激。脚本代码如下。
var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("crop_specific");
var wsMaterials = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("materials");
var options = wsMaterials.getRange(2,1,wsMaterials.getLastRow()-1,9).getValues();
function onEdit(e){
var activeCell = e.range;
var val = activeCell.getValue();
var r = activeCell.getRow();
var c = activeCell.getColumn();
var wsName = activeCell.getSheet().getName();
if(wsName == "crop_specific" && c === 4 && r>1){
if(val === ""){
ws.getRange(r,5).clearContent();
ws.getRange(r,5).clearDataValidations();
}else {
ws.getRange(r,5).clearContent();
var filteredOptions = options.filter(function(o){ return o[0] ===val });
var listToApply = filteredOptions.map(function(o){return o[1] });
var cell = ws.getRange(r,5);
applyValidationToCell(listToApply,cell);
}
}
}
function applyValidationToCell(list,cell){
var rule = SpreadsheetApp
.newDataValidation()
.requireValueInList(list)
.setAllowInvalid(false)
.build();
cell.setDataValidation(rule);
}
答案 0 :(得分:1)
您可以根据下拉选择将一些代码添加到 this page materials
工作表中的数据。
删除 A 列,因为您想从 materials
表中的 B 复制到 I。
将值复制到 crop_specific
表中的 E 到 L 范围内。
我对 crop_specific
表有些担心:
数据粘贴在从编辑的行开始的 E-L 范围内。所以我假设您要清除该范围内的先前内容,否则新值将覆盖该范围的一部分。
E 列包含一个下拉菜单,具体取决于 D 列的值。也许您想下拉该下拉菜单,以便将其应用于 E 列中的其他单元格。
var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("crop_specific");
var wsMaterials = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("materials");
var options = wsMaterials.getRange(2,1,wsMaterials.getLastRow()-1,9).getValues();
function onEdit(e){
var activeCell = e.range;
var val = activeCell.getValue();
var r = activeCell.getRow();
var c = activeCell.getColumn();
var wsName = activeCell.getSheet().getName();
if(wsName == "crop_specific" && c === 4 && r>1){
if(val === ""){
ws.getRange(r,5).clearContent();
ws.getRange(r,5).clearDataValidations();
}else {
ws.getRange(r,5).clearContent();
var filteredOptions = options.filter(function(o){ return o[0] ===val });
var listToApply = filteredOptions.map(function(o){return o[1] });
var cell = ws.getRange(r,5);
applyValidationToCell(listToApply,cell);
var matData = wsMaterials.getDataRange().getValues().filter(r=>r[0]===val); // new code
matData.forEach(a => a.splice(0, 1)); // new code
ws.getRange("E2:L" + ws.getLastRow()).clearContent(); // new code
ws.getRange(r,5,matData.length,matData[0].length).setValues(matData); // new code
}
}
}
function applyValidationToCell(list,cell){
var rule = SpreadsheetApp
.newDataValidation()
.requireValueInList(list)
.setAllowInvalid(false)
.build();
cell.setDataValidation(rule);
}