Google Script: ошибка, из-за которой переменные отображаются в автоматическом письме в правильном формате - PullRequest
0 голосов
/ 29 января 2020

Я настроил автоматические электронные письма на листе Google, но цифры и даты, на которые он ссылается, не форматируют их должным образом, как показано на листах. Может кто-нибудь, пожалуйста, помогите мне в том, что мне нужно изменить, чтобы проценты не были нормальными числами, до второго знака после запятой. И дату использовать формат мм / дд / гггг.

var EMAIL_DRAFTED = "EMAIL DRAFTED";

function weekly_report() {
  var ss = SpreadsheetApp.getActiveSpreadsheet(); //replace with source ID
  var sheet = ss.getSheetByName('Individual Report Emails');                         // replace with source Sheet tab name
  var startRow = 2;                                                                  // First row of data to process
  var numRows = sheet.getLastRow() - 1;                                              // Number of rows to process
  var lastColumn = sheet.getLastColumn();                                            // Last column
  var dataRange = sheet.getRange(startRow, 1, numRows, lastColumn)                   // Fetch the data range of the active sheet
  var data = dataRange.getValues();                                                  // Fetch values for each row in the range
  
  // Work through each row in the spreadsheet
  for (var i = 0; i < data.length; ++i) {
    var row = data[i];  
    // Assign each row a variable
    var Isa = row[0];                              // Col A: ISA
    var IsaEmail = row[1];                         // Col B: Email
    var LastWeekTotalAudits = row[12];             // Col M: Last Week Total Audits
    var LastWeekQualifiers = row[13];              // Col N: Last Week Qualifiers
    var LastWeekObjection = row[14];               // Col O: Last Week Objection
    var LastWeekTransferred = row[15];             // Col P: Last Week Transferred
    var LastWeekDocumented = row[16];              // Col Q: Last Week Documented
    var LastWeekDiction = row[17];                 // Col R: Last Week Diction
    var LastWeekTone = row[18];                    // Col S: Last Week Tone
    var LastWeekKnowledge = row[19];               // Col T: Last Week Knowledge
    var LastWeekAverage = row[20];                 // Col U: Last Week Average
    var LastWeekConversions = row[21];             // Col V: Last Week Conversions
    var WeekBeforeLastTotalAudits = row[22];       // Col W: Week Before Last Total Audits
    var WeekBeforeLastQualifiers = row[23];        // Col X: Week Before Last Qualifiers
    var WeekBeforeLastObjection = row[24];         // Col Y: Week Before Last Objection
    var WeekBeforeLastTransferred = row[25];       // Col Z: Week Before Last Transferred
    var WeekBeforeLastDocumented = row[26];        // Col AA: Week Before Last Documented
    var WeekBeforeLastDiction = row[27];           // Col AB: Week Before Last Diction
    var WeekBeforeLastTone = row[28];              // Col AC: Week Before Last Tone
    var WeekBeforeLastKnowledge = row[29];         // Col AD: Week Before Last Knowledge
    var WeekBeforeLastAverage = row[30];           // Col AE: Week Before Last Average
    var WeekBeforeLastConversions = row[31];       // Col AF: Week Before Last Conversions
    var LastWeekSoW = row[54];                     // Col BC: Last Week SoW
    var LastWeekEoW = row[55];                     // Col BD: Last Week EoW
    var WkDifTotalAudits = row[64];                // Col BM: WkDif Total Audits
    var WkDifQualifiers = row[65];                 // Col BN: WkDif Qualifiers
    var WkDifObjection = row[66];                  // Col BO: WkDif Objection
    var WkDifTransferred = row[67];                // Col BP: WkDif Transferred
    var WkDifDocumented = row[68];                 // Col BQ: WkDif Documented
    var WkDifDiction = row[69];                    // Col BR: WkDif Diction
    var WkDifTone = row[70];                       // Col BS: WkDif Tone
    var WkDifKnowledge = row[71];                  // Col BT: WkDif Knowledge
    var WkDifAverage = row[72];                    // Col BU: WkDif Average
    var WkDifConversions = row[73];                // Col BV: WkDif Conversions
    var emailStatus = row[84];                     // Col CG: Email Status
    
    // Prevent from drafing duplicates and from drafting emails without a recipient
    if (emailStatus !== EMAIL_DRAFTED && IsaEmail) {  
    
      // Build the email message
      var emailBody =  '<h2><strong>WEEKLY AUDIT REVIEW  </strong></h2>' ;
          emailBody += '<h3><strong>' + LastWeekSoW + ' - ' + LastWeekEoW + '  </strong></h3>' ;
          emailBody += '<hr />';
          emailBody += '<h3><strong>Last Week:  </strong></h3>' ;
          emailBody += '<p><strong>Audits Performed:        </strong>' + LastWeekTotalAudits + '<br /><strong>Avg Qualifiers %:  </strong>' + LastWeekQualifiers + '<br /><strong>Avg Objection %:  </strong>' + LastWeekObjection + '<br /><strong>Avg Transferred %:  </strong>' + LastWeekTransferred + '<br /><strong>Avg Documented %:  </strong>' + LastWeekDocumented + '<br /><strong>Avg Diction %:  </strong>' + LastWeekDiction + '<br /><strong>Avg Tone %:  </strong>' + LastWeekTone + '<br /><strong>Avg Knowledge %:  </strong>' + LastWeekKnowledge + '<br /><strong>Last Week Average:  </strong>' + LastWeekAverage + '</p>';
          emailBody += '<hr />';
          emailBody += '<h3><strong>Week Prior:  </strong></h3>' ;
          emailBody += '<p><strong>Audits Performed:  </strong>' + WeekBeforeLastTotalAudits + '<br /><strong>Avg Qualifiers %:  </strong>' + WeekBeforeLastQualifiers + '<br /><strong>Avg Objection %:  </strong>' + WeekBeforeLastObjection + '<br /><strong>Avg Transferred %:  </strong>' + WeekBeforeLastTransferred + '<br /><strong>Avg Documented %:  </strong>' + WeekBeforeLastDocumented + '<br /><strong>Avg Diction %:  </strong>' + WeekBeforeLastDiction + '<br /><strong>Avg Tone %:  </strong>' + WeekBeforeLastTone + '<br /><strong>Avg Knowledge %:  </strong>' + WeekBeforeLastKnowledge + '<br /><strong>Prior Week Average:  </strong>' + WeekBeforeLastAverage + '</p>';
          emailBody += '<hr />';
          emailBody += '<h3><strong>Variance:  </strong></h3>' ;
          emailBody += '<p><strong>Audits Performed:  </strong>' + WkDifTotalAudits + '<br /><strong>Avg Qualifiers %:  </strong>' + WkDifQualifiers + '<br /><strong>Avg Objection %:  </strong>' + WkDifObjection + '<br /><strong>Avg Transferred %:  </strong>' + WkDifTransferred + '<br /><strong>Avg Documented %:  </strong>' + WkDifDocumented + '<br /><strong>Avg Diction %:  </strong>' + WkDifDiction + '<br /><strong>Avg Tone %:  </strong>' + WkDifTone + '<br /><strong>Avg Knowledge %:  </strong>' + WkDifKnowledge + '<br /><strong>Avg Variance:  </strong>' + WkDifAverage + '</p>';
          emailBody += '<hr />';
          emailBody += '<p><strong>In the event of poor performance, a manager will review with you.  </strong>' ;
      
      // Create the email draft
      MailApp.sendEmail(
        IsaEmail,                                         // Recipient
        'Your Weekly Call Audit Review for' + LastWeekSoW + ' - ' + LastWeekEoW,  // Subject
        '',                                               // Body (plain text)
        {
        htmlBody: emailBody                               // Options: Body (HTML)
        }
      );
      
      sheet.getRange(startRow + i, lastColumn).setValue(EMAIL_DRAFTED); // Update the last column with "EMAIL_DRAFTED"
      SpreadsheetApp.flush(); // Make sure the last cell is updated right away
    }
  }
}

Но в электронных письмах это выглядит примерно так: Пример текущего неправильного форматирования электронной почты

Ответы [ 2 ]

1 голос
/ 29 января 2020

Если вы хотите получить отображаемое значение, вы должны использовать getDisplayValues ​​. Вы бы изменили строку с вашей переменной данных на эту.

  var data = dataRange.getDisplayValues();// Fetch values for each row in the range
0 голосов
/ 30 января 2020
  • Чтобы ограничить количество десятичных знаков до двух, вы можете использовать toFixed :
var numberToSend = numberFromSheet.toFixed(2);
  • Если вы хотите, чтобы он отображал в процентах, вы можете сделать это вместо:
var numberToSend = (numberFromSheet * 100).toFixed(2) + "%";
  • Чтобы форматировать дату в соответствии с вашими предпочтениями, вы можете использовать formatDate :
var dateToSend = Utilities.formatDate(dateFromSheet, yourTimeZone, "MM/dd/yyyy");

Ссылка:

Надеюсь, это поможет.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...