Идентификатор цикла через ячейки в скрипте Google Apps

Добрый день! Я хочу, чтобы идентификатор заказа на покупку автоматически повторялся при отправке формы на предыдущем листе. Однако мой текущий код повторяет это по всей длине диапазона данных, а не только для ячеек с содержимым в указанном диапазоне данных. Могу ли я получить помощь в изменении кода или оператора цикла/если ниже? Заранее спасибо.

function exportPO() {
var myGooglSheet = SpreadsheetApp.getActive();
var shSource = myGooglSheet.getSheetByName("Source");
var shDatabase = myGooglSheet.getSheetByName("Database");
var lastRow = shDatabase.getLastRow()

var ProductValues = shSource.getRange("B5:C14").getValues();
shDatabase.getRange(lastRow+1,2,ProductValues.length,2).setValues(ProductValues);

var PO = shSource.getRange("C1").getValues();
var lines = 0;

var ProductRow = ProductValues.length;
for(var i=0; i<ProductRow; i++)
  if (ProductValues!=''){
  lines= lines+1;
  shDatabase.getRange(lastRow+lines,1).setValues(PO);
  shDatabase.getRange(lastRow+lines,4).setValue(new Date()).setNumberFormat('yyyy-mm- 
  dd h:mm'); //Submitted On

В качестве предположения попробуйте изменить if (ProductValues!=''){ на if (ProductValues[i][0]=''){ или if (ProductValues[i][1]!=''){ или что-то в этом роде. Поскольку ProductValues — это двумерный массив.

Yuri Khristich 09.04.2022 14:44
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
1
1
32
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

В связи с

var ProductValues = shSource.getRange("B5:C14").getValues();

Строка выше присваивает массив массивов ProductValues

В связи с

ProductValues!=''

Приведенное выше выражение всегда будет возвращать false. Вы можете изменить это на ProductValues[i].every(value => value != ''), чтобы сравнить все значения в строке с пустой строкой, если все не являются пустой строкой, это вернет true, иначе false, или измените исходное выражение на что-то вроде ProductValues[i][0]!='', чтобы сравнить значение каждого row в пустую строку, первый индекс соответствует строке, второй — столбцу.

Другие вопросы по теме