簡體   English   中英

Google表格:同一表格和同一腳本上的兩組相關下拉列表

[英]Google Sheets: two sets of dependent drop down lists on same sheet and same script

三個小時前,我根本不知道怎么做依賴下拉列表。 現在,我有一個數據驗證列,在選擇數據時,將為下一個單元格提供一個下拉列表。 但是,我想這樣做兩次。 問題是,我不知道如何在腳本中復制它。 這就是我什至走到這一步的方式

這是我的 Google 表格的鏈接

這是我在嘗試處理 FEEDBACK 列之前的代碼。 TECHNICAL 列按預期工作:

var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Raw Data");
var wsTechnical = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Drop Downs - Technical");
var technical = wsTechnical.getRange(2, 1,wsTechnical.getLastRow()-1,2).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 == "Raw Data" && c === 6 &&  r > 2){

    if(val === ""){
      ws.getRange(r, 7).clearContent();
      ws.getRange(r, 7).clearDataValidations();
    } else {
      ws.getRange(r, 7).clearContent();
      var filteredTechnical = technical.filter(function(t){ return t[0] === val });
      var listToApply = filteredTechnical.map(function(t){ return t[1] });
      var cell = ws.getRange(r, 7);
      applyValidationToCell(listToApply,cell);
    }
  }
}


function applyValidationToCell(list,cell){

  var rule = SpreadsheetApp
  .newDataValidation()
  .requireValueInList(list)
  .setAllowInvalid(false)
  .build();

  cell.setDataValidation(rule)
}

這就是我改變它的方式,希望它能為 FEEDBACK 列創建相同的流程,但它完全沒有改變; TECHNICAL 列仍按預期工作,但 FEEDBACK 列不能:

var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Raw Data");
var wsFeedback = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Drop Downs - Feedback");
var feedback = wsFeedback.getRange(2, 1,wsFeedback.getLastRow()-1,2).getValues();
var wsTechnical = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Drop Downs - Technical");
var technical = wsTechnical.getRange(2, 1,wsTechnical.getLastRow()-1,2).getValues();

function onEdit(e){
  var activeCell = e.range;
  var val = activeCell.getValue();
  var r = activeCell.getRow();
  var c = activeCel1.getColumn();
  var wsName = activeCell.getSheet().getName();
  if(wsName == "Raw Data" && c === 4 &&  r > 2){

    if(val === ""){
      ws.getRange(r, 5).clearContent();
      ws.getRange(r, 5).clearDataValidations();
    } else {
      ws.getRange(r, 5).clearContent();
      var filteredFeedback = feedback.filter(function(f){ return f[0] === val });
      var listToApply = filteredFeedback.map(function(f){ return f[1] });
      var cell = ws.getRange(r, 5);
      applyValidationToCell(listToApply,cell);
    }
  }
}

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 == "Raw Data" && c === 6 &&  r > 2){

    if(val === ""){
      ws.getRange(r, 7).clearContent();
      ws.getRange(r, 7).clearDataValidations();
    } else {
      ws.getRange(r, 7).clearContent();
      var filteredTechnical = technical.filter(function(t){ return t[0] === val });
      var listToApply = filteredTechnical.map(function(t){ return t[1] });
      var cell = ws.getRange(r, 7);
      applyValidationToCell(listToApply,cell);
    }
  }
}


function applyValidationToCell(list,cell){

  var rule = SpreadsheetApp
  .newDataValidation()
  .requireValueInList(list)
  .setAllowInvalid(false)
  .build();

  cell.setDataValidation(rule)
}

任何幫助,將不勝感激!

編輯:同樣,我對腳本幾乎一無所知,而且……所有這些。 如果願意,請為我降低答案。 謝謝!

您的問題在於您的onEdit(e)函數。

當 Google 檢測到進行了編輯時,它會調用onEdit() function,但是,如果有兩個,它不會同時調用,只會調用第一個。

要解決此問題,請對您的代碼執行以下操作:

var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Raw Data");
var wsFeedback = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Drop Downs - Feedback");
var feedback = wsFeedback.getRange(2, 1,wsFeedback.getLastRow()-1,2).getValues();

var ws = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Raw Data");
var wsTechnical = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Drop Downs - Technical");
var technical = wsTechnical.getRange(2, 1,wsTechnical.getLastRow()-1,2).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 == "Raw Data" && c === 4 &&  r > 2){

    if(val === ""){
      ws.getRange(r, 5).clearContent();
      ws.getRange(r, 5).clearDataValidations();
    } else {
      ws.getRange(r, 5).clearContent();
      var filteredFeedback = feedback.filter(function(f){ return f[0] === val });
      var listToApply = filteredFeedback.map(function(f){ return f[1] });
      var cell = ws.getRange(r, 5);
      applyValidationToCell(listToApply,cell);
    }
  } else if(wsName == "Raw Data" && c === 6 &&  r > 2){
    if(val === ""){
      ws.getRange(r, 7).clearContent();
      ws.getRange(r, 7).clearDataValidations();
    } else {
      ws.getRange(r, 7).clearContent();
      var filteredTechnical = technical.filter(function(t){ return t[0] === val });
      var listToApply = filteredTechnical.map(function(t){ return t[1] });
      var cell = ws.getRange(r, 7);
      applyValidationToCell(listToApply,cell);
    }
  }
}

function applyValidationToCell(list,cell){

  var rule = SpreadsheetApp
  .newDataValidation()
  .requireValueInList(list)
  .setAllowInvalid(false)
  .build();

  cell.setDataValidation(rule)
}

希望這可以幫助!

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM