Электронная почта не отправляется

#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-массив). Я не могу проверить ваш код, так что просто предположение.