如果单元格为空,则替换值时出现问题

时间:2017-02-15 16:29:34

标签: javascript google-apps-script google-sheets gmail-api

在我的Google Apps电子表格中,我有多个列:首先是row[0]表示签入日期,第二列是row[1]表示结帐日期......依此类推至row[17] 。我的功能是为新注册的预订发送确认,由预订状态栏row[16])确定,如果单元格中包含的值是Новое бронирование而不是函数向前台经理发送通知(但如果值不同,那么除了检查列单元格的值之外,它什么都不做。)

问题是我无法修改我的功能以发送 reservationNotes row[11])当且仅当相应行中的单元格(即带有新预订)包含预订备注时本身:row[11]中的单元格值应该不为空

以下是源代码:

/* Отправка уведомлений о добавлении новых бронирований (т.е., новых строк в таблице на активном листе). */
function NotifyManagerOfNewReservation() {
    var ss = SpreadsheetApp.getActiveSpreadsheet();
    var sheet = SpreadsheetApp.getActiveSheet();
    var startRow = 2; // Строка с первым бронированием для начала обработки.
    var numRows = sheet.getLastRow()-1; // Количество строк с бронированиями для обработки.
    var dataRange = sheet.getRange(startRow, 1, numRows, 18); // Охват столбцов для обработки ячеек, в данном случае с 1-го по 18-ый.
    var data = dataRange.getValues(); // Получить значение ячеек в каждой ячейке каждой строке в рамках столбцов, охваченных верхним кодом.
    var statusNewReservation = "Новое бронирование";
    var statusNotificationSent = "Уведомление отправлено";
    for (var i = 0; i < data.length; ++i) {
        var row = data[i];
        var checkInDate = new Date(row[0]);
        var checkOutDate = new Date(row[1]);
        var formattedCheckInDate = Utilities.formatDate(checkInDate, "GMT+0300", "dd.MM.yyyy");
        var formattedCheckOutDate = Utilities.formatDate(checkOutDate, "GMT+0300", "dd.MM.yyyy");
        var fullCheckInDate = Utilities.formatDate(checkInDate, "GMT+0300", "dd.MM.yyyy") + " в 14:00";
        var fullCheckOutDate = Utilities.formatDate(checkOutDate, "GMT+0300", "dd.MM.yyyy") + " в 12:00";
        var reservationNumber = [i+2] + "0" + checkInDate.getFullYear(); // С 18:35, 26.09.2016 (МСК) используется универсальный формат номера бронирований (до этого момента он формировался по формуле [i+2]).
        var roomType = "«" + row[2] + "»";
        var numberOfGuests = row[3];
        var numberOfNights = Math.round(Math.abs((checkOutDate.getTime() - checkInDate.getTime())/(24*60*60*1000)));
        var costPerNight = row[4];
        var prepaymentCost = row[8];
        var unpaidCost = (costPerNight*numberOfNights)-prepaymentCost;
        var formattedNumberOfNights = numberOfNights + " ночей"; // Количество ночей проживания.
        var formattedCostPerNight = costPerNight + " руб.";
        var formattedPrepaymentCost = prepaymentCost + " руб.";
        var formattedUnpaidCost = unpaidCost + " руб."; // Сумма, которую необходимо оплатить гостю по приезде.
        var contactFullName = row[5];
        var contactPhone = row[6];
        var contactEmail = row[7];
        var reservationNotes = row[11];
        var fullReservationNotes = "";
        var notificationStatus = row[16]; // Столбец, в котором выставляется статус отправки/неотправки уведомлений о новых бронированиях.
        var reservationsListLink = "https://www.berdyanskaya56.ru/intranet/reservations/";
        /* Установка параметров отправителя. */
        var senderAliases = GmailApp.getAliases(); // Запрашиваем список всех элиасов электропочтового аккаунта.
        Logger.log(senderAliases); // Проверяем список электропочтовых эллиасов и выбираем требующийся в формате senderAliases[N], где алиас, идущий первым по порядку, имеет значение «0» (к примеру, senderAliases[0] для ruslanseletskiy@gmail.com).
        var senderAddress = "ruslan@berdyanskaya56.ru"; // Указываем выбранный алиас.
        var senderName = "Робот Руслана (мини-гостиница «Бердянская 56»)"; // Уточняем имя отправителя.
        var replyTo = "ruslan@berdyanskaya56.ru"; // Указываем электропочтовый адрес для ответа.
        var highriseDropbox = "dropbox@18407830.minihotelberdyanskaya56.highrisehq.com"; // Адрес общего ящика аккаунта ruslan@berdyanskaya56.ru в Хайрайзе.
        var bccAddress = highriseDropbox;
        var managerEmail = "natalya@berdyanskaya56.ru"; // Электропочта менеджера фронт-офиса.
        var subject = "Новое бронирование № " + reservationNumber + " (" + contactFullName + ")";
        /* Не показываем строку с примечаниями к бронированию в случае их отсутствия. */
        if (reservationNotes !== "") {fullReservationNotes == "\nПримечания к бронированию: " + reservationNotes + "\n"}
        var message = "Добавлено бронирование № " + reservationNumber + "!" + "\n" + "\nДанные нового бронирования:" + "\n" + "\nЗаезд: " + fullCheckInDate + "\nВыезд: " + fullCheckOutDate + "\nНомер: " + roomType + "\nТип размещения: " + numberOfGuests + "\n" + "\nКоличество ночей: " + formattedNumberOfNights + "\nЦена за ночь: " + formattedCostPerNight + "\nВнесённый депозит: " + formattedPrepaymentCost + "\n(" + formattedCostPerNight + " × " + formattedNumberOfNights + ")" + " – " + formattedPrepaymentCost + " = " + formattedUnpaidCost + " к оплате" + "\n" + "\nИмя и фамилия гостя: " + contactFullName + "\nМобильный телефон: " + contactPhone + "\nЭлектронная почта: " + contactEmail + "\n" + fullReservationNotes + "\nПожалуйста, срочно сделай занятым номер " + roomType + " в период с " + formattedCheckInDate + " (с 14:00)" + " по " + formattedCheckOutDate + " (до 12:00)" + " в экселевском файле!" + "\n" + "\n* Посмотреть полный список бронирований всегда можно тут: " + reservationsListLink + ".";  
            if (notificationStatus == statusNewReservation) { // Условное выражение, позволяющее не отправлять письма о тех же бронировациях повторно.
            // MailApp.sendEmail(managerEmail, subject, message, {name: senderName, replyTo: replyTo});
            GmailApp.sendEmail(managerEmail, subject, message, {from: senderAddress, name: senderName, replyTo: replyTo, bcc: bccAddress});
            sheet.getRange(startRow + i, 17).setValue(statusNotificationSent);
            Logger.log("Отправлено уведомление о новом бронировании № " + reservationNumber + " (" + contactFullName + ")" + " на " + managerEmail + ".");
            }
            SpreadsheetApp.flush(); // Показываем пользователю что изменения вступают в силу.
       }
}

我使用“间接”变量fullReservationNotes来检查if (reservationNotes !== "") {fullReservationNotes == "\nПримечания к бронированию: " + reservationNotes + "\n"}是否实现了这一点,但它无法正常工作:即使reservationNotes中的单元格也没有显示任何预留备注(row[11])列已填充或如果为空。

因此,如果row[11]中的单元格对于任何已添加的预留为空,那么"\nПримечания к бронированию: " + reservationNotes + "\n"中应该没有放置,而fullReservationNotes也应该留空在通知消息中。

我也花了半个小时搜索现有的问题,但我没有发现任何类似的情况。

如何解决这个问题?也许我错过了上面描述if循环的循环?

非常感谢你为解决这个问题所做的一切贡献!

2 个答案:

答案 0 :(得分:0)

如果我正确阅读,我认为问题出在if之后,你使用比较运算符(==)而不是赋值运算符(=)

尝试:

if (reservationNotes !== "") {fullReservationNotes = "\nПримечания к бронированию: " + reservationNotes + "\n"}

答案 1 :(得分:0)

我在代码中看到的唯一问题是在完整的reservationNotes赋值结束时没有分号,我也不认为==是赋值运算符。

if (reservationNotes !== "") 
{
   fullReservationNotes == "\nПримечания к бронированию: " + reservationNotes + "\n"
}