在我的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循环的循环?
非常感谢你为解决这个问题所做的一切贡献!
答案 0 :(得分:0)
如果我正确阅读,我认为问题出在if之后,你使用比较运算符(==)而不是赋值运算符(=)
尝试:
if (reservationNotes !== "") {fullReservationNotes = "\nПримечания к бронированию: " + reservationNotes + "\n"}
答案 1 :(得分:0)
我在代码中看到的唯一问题是在完整的reservationNotes赋值结束时没有分号,我也不认为==是赋值运算符。
if (reservationNotes !== "")
{
fullReservationNotes == "\nПримечания к бронированию: " + reservationNotes + "\n"
}