动态下拉菜单设置为自动填充下一列

时间:2019-02-25 23:13:17

标签: google-apps-script google-sheets google-sheets-formula

我工作的公司在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");
      }
  }

我可以更改使其仅显示第二行中的值,而不显示当前显示的数据验证范围吗?

1 个答案:

答案 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);
      }
  }