#javascript #google-apps-script #google-sheets #sendmail
Вопрос:
Код Не содержит ошибок, Но я Не получаю и не отправляю электронную почту, когда проверяю свой gmail
Эта строка-проблема, я считаю, что пишу это неправильно, поэтому не отправляю электронное письмо, пожалуйста, помогите
if(values.getDisplayValues() === "On-going" || values.getDisplayValues() === "" amp;amp; values1.getDisplayValues() >= 80)
Остальная часть кода:
function sendEmail(){
var ss = SpreadsheetApp.getActiveSpreadsheet();
var SpreadsheetID = ss.getSheetId();
var spreadsheetURL = ss.getUrl();
var SpreadsheetID = spreadsheetURL.split("/")[5];
var filterViewName = 'PO_Log Precentage';
var filterViewID = filterId(SpreadsheetID, filterViewName);
var url = createURL(spreadsheetURL, filterViewID);
Logger.log(url);// Testing to see the correct url is created
var po_numID = ss.getSheetByName("Purchase Orders List").getRange("A2").getDisplayValue().substr(0,3);
Logger.log(po_numID);
var email_va = ss.getSheetByName("Purchase Orders List");
var values = email_va.getRange("Q2:Q");
var values1 = email_va.getRange("T2:T");
Logger.log(values)
var emailDataSheet = SpreadsheetApp.openByUrl("https://docs.google.com/spreadsheets/d/17G0QohHxjuAcZzwRtQ6AUW3aMTEvLnmTPs_USGcwvDA/edit#gid=1242890521").getSheetByName("TestA");
Logger.log(emailDataSheet.getSheetName());
var emailData = emailDataSheet.getRange("A2:A").getDisplayValues().flat().map(po => po.substr(0,3));
Logger.log(emailData)
var subject = po_numID " Po Log Daily Notification ";
var options = {}
options.htmlBody = "Hi All, " "The following" '<a href="' url '" > Purchase Orders </a>' "are over 80% spent" "";
// I believe this if statement is the problem I am writing it in correctly
if(values.getDisplayValues() === "On-going" || values.getDisplayValues() === "" amp;amp; values1.getDisplayValues() >= "80%"){
emailData.every((po, index) => {
if (po == po_numID){
const email = emailDataSheet.getRange(index 2,7).getValue();
console.log(email);
MailApp.sendEmail(email, subject, '', options);
return false;
} else {
return true;
}
});
}
}
https://docs.google.com/spreadsheets/d/1QW5PIGzy_NSh4MT3j_7PggxXq4XcW4dCKr4wKqIAp0E/edit#gid=611584429
Вот развернутый лист
Ответ №1:
values.getDisplayValues()
дает вам массив.
В принципе, нет смысла сравнивать массив и строку с ===
и >=
т. Д.
Вам нужно решить, какой элемент массива должен быть. Может быть что-то вроде values.getDisplayValues()[0][0]
(потому что это, скорее всего, 2D-массив). Я не могу проверить ваш код, так что просто предположение.