it-swarm.com.ru

Скрипты таблиц Google: проверьте, пуста ли ячейка

Я хочу ввести переменную в ячейку, только если ячейка пуста. Оператор if, однако, не работает. Любой совет?

var ss=SpreadsheetApp.getActiveSpreadsheet();
var r=ss.getRange("'odpovědi'!A2:J");

var rws=r.getNumRows();

ax=r.getCell(rws-1, 10).getValue();

if (ax == "") {
  ax = "foo";
  r.getCell(rws-1, 9).setValue(ax);
}
8
orobinec

Нет необходимости извлекать значение, чтобы определить, является ли ячейка пустой. В Google Spreadsheet API уже есть метод для этого: Range - метод isBlank

var cell = r.getCell(rws-1, 10);

if (cell.isBlank()) {
    cell.setValue("foo");
}
8
A. Masson

Пытаться:

function myFunction() {
  var ss=SpreadsheetApp.getActiveSpreadsheet();
  var s=ss.getSheetByName('odpovědi')
  var lr=s.getLastRow()  
  var ax=s.getRange(lr, 10).getValue();
     if(ax == ""){
        ax = "foo";
        s.getRange(lr, 10).setValue(ax);
  }
  }
3
Ed Nelson

Если у вас уже есть значение ячейки, используйте операторы === или !==, если вы хотите избежать преобразования типов (где 0 == ""). 

Фрагмент кода для уменьшения значений непустых ячеек

var sheet = ss.getSheets()[0];     
var range = sheet.getRange("E2:H5");
var currentValues = range.getValues();  

var newValues = [];
for (var row in currentValues) {
  var newRow = []; 
  for (var col in currentValues[row]) {
    if (currentValues[row][col] !==  "") { // if not empty cell
      newRow[col] = currentValues[row][col] - 1;          
    }
    else {
      newRow[col] = currentValues[row][col];
    }
  }
  newValues[row] = newRow;
}    
range.setValues(newValues);
1
koxt