我工作的公司在Google表格中存储了大量数据,许多人都可以访问它并具有编辑权限。为了使事情保持一致,我在整个工作表中设置了一些公式/脚本。
我目前遇到的问题基本上是一个脚本,该脚本将运行IF公式,并在该单元格等于特定值之前显示一个设置值。因此,列K的数据验证下拉列表超出了A1:I1的范围,如果我选择一个值,它仅需要显示该范围正下方的单元格中的任何数据。我知道可以用一个简单的VLOOKUP来完成,但是我宁愿不要那样做。我当前拥有的脚本是这样的:
function onEdit(){
var tabPhase = "Authenticated";
var spreadSheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var dataYear = SpreadsheetApp.getActiveSpreadsheet().getSheetByName(tabPhase);
var activeCell = spreadSheet.getActiveCell();
if(activeCell.getColumn() == 11 && activeCell.getRow() > 1 && spreadSheet.getSheetName() == tabPhase){
activeCell.offset(0, 1).clearContent().clearDataValidations();
var makes = dataYear.getRange(1, 1, 1, dataYear.getLastColumn()).getValues();
var makeIndex = makes[0].indexOf(activeCell.getValue()) + 1;
if(makeIndex != 0){
var validationRange = dataYear.getRange(3, makeIndex, dataYear.getLastRow());
var validationRule = SpreadsheetApp.newDataValidation().requireValueInRange(validationRange).build();
activeCell.offset(0, 1).setDataValidation(validationRule);
}
}
}
它几乎完美地工作,我遇到的唯一问题是L列中的单元格然后输出了数据验证。
我还可以使用嵌套的if语句来使它工作,但是我不确定如何从单元格中提取数据,而不是仅仅显示先前设置的数据。这是代码:
function onEdit() {
var ss = SpreadsheetApp.getActiveSpreadsheet();
var aSheet = ss.getActiveSheet();
var aCell = aSheet.getActiveCell();
var aColumn = aCell.getColumn();
var aRow = aCell.getRow();
var licenseTypeCell = aSheet.getRange(aRow, aColumn+1);
var aValue = aCell.getValue()
if (aColumn == 1 && aSheet.getName() == 'Authenticated Ranges') {
var matchCell = aSheet.getRange(aRow, aColumn).getValue()
if(matchCell == "A1")
licenseTypeCell.setValue("A2");
if(matchCell == "B1")
licenseTypeCell.setValue("B2");
if(matchCell == "C1")
licenseTypeCell.setValue("C2");
if(matchCell == "D1")
licenseTypeCell.setValue("D2");
}
}
我可以更改使其仅显示第二行中的值,而不显示当前显示的数据验证范围吗?
答案 0 :(得分:0)
我花了很多时间来解决这个问题,最终还是弄清楚了。当然,欢迎提出任何精简建议,因为我知道这段代码仅是功能性的,并不十分漂亮!
function onEdit() {
var app = SpreadsheetApp;
var activeSheet = app.getActiveSpreadsheet().getActiveSheet();
var aSheet = app.getActiveSheet();
var aCell = aSheet.getActiveCell();
var aColumn = aCell.getColumn();
var aRow = aCell.getRow();
var targetSheet = app.getActiveSpreadsheet().getSheetByName("Authenticated");
var A1 = targetSheet.getRange(2,1).getValue();
var B1 = targetSheet.getRange(2,2).getValue();
var C1 = targetSheet.getRange(2,3).getValue();
var D1 = targetSheet.getRange(2,4).getValue();
var E1 = targetSheet.getRange(2,5).getValue();
var licenseTypeCell = aSheet.getRange(aRow, aColumn+1);
var aValue = aCell.getValue()
if (aColumn == 16 && aSheet.getName() == 'Master') {
var matchCell = aSheet.getRange(aRow, aColumn).getValue()
if(matchCell == "A1")
licenseTypeCell.setValue(A1);
if(matchCell == "B1")
licenseTypeCell.setValue(B1);
if(matchCell == "C1")
licenseTypeCell.setValue(C1);
if(matchCell == "D1")
licenseTypeCell.setValue(D1);
if(matchCell == "E1")
licenseTypeCell.setValue(E1);
}
}