Как вернуть процент отформатированных ячеек? - PullRequest
0 голосов
/ 05 февраля 2019

Приведенный ниже код получает лист, на котором хранятся данные, и получает данные с использованием циклов, а также копирует форматирование каждой ячейки.

Проблема заключается в том, что он не работает с процентными ячейкамиотформатированный, т.е. на листе данные составляют 8,7%, и на моем выходном письме я получаю 8,766656454545454.

Как я могу это исправить и получить именно то, что на листе?

  function shrinkageEmail() {
    var getSheet = DriveApp.getFileById('xxxxxxxxxx');
    var getID = getSheet.getId();
    var ss = SpreadsheetApp.openById(getID);
    var sheet = ss.getSheetByName("SUMMARY");
    var range = sheet.getDataRange();
    var recipient = 'cxxxx@google.com';
    var date = Utilities.formatDate(new Date(), "GMT+1", "yyyy-MM-dd");
    var subject = 'Morning Shift Shrinkage Report '+date;
    var schedRange = sheet.getRange("C16:J34"); 
    var body = '<div style="text-align:center;display: inline-block;font-family: arial,sans,sans-serif">'
    body += '<H1>'+ 'Shrinkage Report ' +'</H1>';
    body += '<H2>'
    body += getHtmlTable(schedRange);
    body += '</div>';
    debugger;
    //recipient = 'xxxxxxx@google.com';  // For debugging, send only to self
    GmailApp.sendEmail(recipient, subject, "Requires HTML", {htmlBody:body})
  }

  /**
  * Return a string containing an HTML table representation
  * of the given range, preserving style settings.
  */
  function getHtmlTable(range){
    var ss = range.getSheet().getParent();
    var sheet = range.getSheet();
    startRow = range.getRow();
    startCol = range.getColumn();
    lastRow = range.getLastRow();
    lastCol = range.getLastColumn();

    // Read table contents
    var data = range.getValues();

    // Get css style attributes from range
    var fontColors = range.getFontColors();
    var backgrounds = range.getBackgrounds();
    var fontFamilies = range.getFontFamilies();
    var fontSizes = range.getFontSizes();
    var fontLines = range.getFontLines();
    var fontWeights = range.getFontWeights();
    var horizontalAlignments = range.getHorizontalAlignments();
    var verticalAlignments = range.getVerticalAlignments();

    // Get column widths in pixels
    var colWidths = [];
    for (var col=startCol; col<=lastCol; col++) { 
      colWidths.push(sheet.getColumnWidth(col));
    }

    // Get Row heights in pixels
    var rowHeights = [];
    for (var row=startRow; row<=lastRow; row++) { 
      rowHeights.push(sheet.getRowHeight(row));
    }

    // Build HTML Table, with inline styling for each cell
    var tableFormat = 'style="font-size: 12px; border:2px solid black;border-collapse:collapse;text-align:center" border = 1.2 cellpadding = 1.2';
    var html = ['<table '+tableFormat+'>'];

    // Column widths appear outside of table rows
    for (col=0;col<colWidths.length;col++) {
      html.push('<col width="'+colWidths[col]+'">')
    }

    // Populate rows
    for (row=0;row<data.length;row++) {
      html.push('<tr height="'+rowHeights[row]+'">');
      for (col=0;col<data[row].length;col++) {
        // Get formatted data
        var cellText = data[row][col];
        if (cellText instanceof Date) {
          cellText = Utilities.formatDate(
            cellText,
            ss.getSpreadsheetTimeZone(),
            'YYYY-MM-DD')

        }
        var style = 'style="'
        + 'color: ' + fontColors[row][col]+'; '
        + 'font-family: ' + fontFamilies[row][col]+'; '
        + 'font-size: ' + fontSizes[row][col]+'; '
        + 'font-weight: ' + fontWeights[row][col]+'; '
        + 'background-color: ' + backgrounds[row][col]+'; '
        + 'text-align: ' + horizontalAlignments[row][col]+'; '
        + 'vertical-align: ' + verticalAlignments[row][col]+'; '
        +'"';
        html.push('<td ' + style + '>'
                  +cellText
                  +'</td>');
      }
      html.push('</tr>');
    }
    html.push('</table>');

    return html.join('');
  }
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...