it-swarm.asia

الحصول على ورقة بالاسم

أحاول الحصول على الصيغة التالية للعمل:

function setDataValid(range, sourceRange) {
  var rule = SpreadsheetApp.newDataValidation().requireValueInRange(sourceRange, true).build();
  range.setDataValidation(rule);
}

function onEdit() {
  var aCell = SpreadsheetApp.getActiveSheet().getActiveCell();
  var aColumn = aCell.getColumn();

  if (aColumn == 2 && SpreadsheetApp.getActiveSheet().getName() == 'Local' ) {
    var range = SpreadsheetApp.getActiveSheet().getRange(aCell.getRow(), aColumn + 1);
    var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());
    setDataValid(range, sourceRange)
  }
}

عند تصحيح onEdit () يُظهر أن sourceRange في setDataValid (النطاق ، sourceRange) لاغٍ. نظرًا لأن النطاق موجود في الورقة "محلي" ، أحاول تغيير getActiveSpreadsheet () إلى جدول الحصول على الاسم. أي شخص يمكن أن تساعد؟

17
Michiel van Dijk

استخدم الحصول على ورقة بالاسم في جدول البيانات:

var sheet = SpreadsheetApp.getActive().getSheetByName('Local')
30
Hink

يرجى التحقق من البيان

var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName(aCell.getValue());

يجب أن يكون هذا هو العائد لاغية. لمعرفة السبب في الوثائق الرسمية هنا .

var sourceRange = SpreadsheetApp.getActiveSpreadsheet().getRangeByName('Local!TaxRates')

يجب أن تحصل على المدى.

1
Suhail Ansari