Arhn - архитектура программирования

Электронная почта Google Таблиц - Vlookup показывает значение REF в PDF

Надеясь, что вы можете мне в этом помочь, я создал систему, которая автоматически отправляет текущий лист в виде вложения в электронное письмо с основным текстом и текстом темы. У меня есть одна проблема, которую я не могу решить; Vlookup, используемый на листе, генерирует либо пустой столбец, либо REF! в отправленном по электронной почте PDF. И любая информация, указывающая на другое значение с другого листа (например, = 'Sheet2'! D2)

Вот код, используемый на листе, запускающий вложение PDF:

    function mailCCB() {
var originalSpreadsheet = SpreadsheetApp.getActive();                            //get active spreadsheet
var message = "Good Day." + "\n\n" + "Please find attached certificate";         //email body
var certNo = originalSpreadsheet.getRange("C7").getValue();                      //certificate number  
var cust = originalSpreadsheet.getRange("E10").getValues();                      //customer name
var subject = "Certificate " + certNo + " | " + cust;                 //email subject
var emailTo = originalSpreadsheet.getRange("E13").getValue();                    //email address
var sheets = originalSpreadsheet.getSheets();                                    //get all sheets
var sheetName = originalSpreadsheet.getActiveSheet().getName();                  //get current sheet name
var sourceSheet = originalSpreadsheet.getSheetByName(sheetName);                 //source sheet
// Get folder containing spreadsheet to save pdf in.
  var parents = DriveApp.getFileById(originalSpreadsheet.getId()).getParents();
  if (parents.hasNext()) {
    var folder =  parents.next();
  }
  else {
    folder = DriveApp.getRootFolder();
  }
SpreadsheetApp.getActiveSpreadsheet().toast("Working on it.. 50%", "Busy",12);
  // Copy whole spreadsheet.
  var destSpreadsheet = SpreadsheetApp.open(DriveApp.getFileById(originalSpreadsheet.getId()).makeCopy("tmp_convert_to_pdf", folder))

  // Delete redundant sheets.
  var sheets = destSpreadsheet.getSheets();
  for (i = 0; i < sheets.length; i++) {
    if (sheets[i].getSheetName() != sheetName){

      destSpreadsheet.deleteSheet(sheets[i]);
    }
  }
  var destSheet = destSpreadsheet.getSheets()[0];
  var sourceRange = sourceSheet.getRange(1,1,sourceSheet.getMaxRows(),sourceSheet.getMaxColumns());
  var sourcevalues = sourceRange.getValues();
SpreadsheetApp.getActiveSpreadsheet().toast("Working on it.. 60%", "Busy",12);
    var destRange = destSheet.getRange(1, 1, destSheet.getMaxRows(), destSheet.getMaxColumns());
  destRange.setValues(sourcevalues);
  var theBlob = destSpreadsheet.getBlob().getAs('application/pdf').setName(subject);
  var newFile = folder.createFile(theBlob);
//*****************************

SpreadsheetApp.getActiveSpreadsheet().toast("Working on it.. 75%", "Busy",12);
// Create a new Spreadsheet and copy the current sheet into it.
var newSpreadsheet = SpreadsheetApp.create("Spreadsheet to export");
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var projectname = SpreadsheetApp.getActiveSpreadsheet();
sheet = originalSpreadsheet.getActiveSheet();
sheet.copyTo(newSpreadsheet);


var pdf = DriveApp.getFileById(originalSpreadsheet.getId()).getAs('application/pdf').getBytes();
var attach = {fileName:'Klerkscale Certificate',content:pdf, mimeType:'application/pdf'};
MailApp.sendEmail(emailTo, subject, message, {attachments:[theBlob]});

DriveApp.getFileById(newSpreadsheet.getId()).setTrashed(true);  

originalSpreadsheet.toast("Certificate will be sent shortly to " + emailTo,"Success",20);
} 

Это обрезанный результат полученного электронного письма:

введите здесь описание изображения


  • Я не могу воспроизвести это, это работает для меня, может ли я привести пример используемых вами функций vlookup и данных, на которые он нацелен (значения и тип данных)? 06.05.2020
  • @AndresDuarte Использование любого из них по-прежнему дает тот же результат, но вот оба: 1. = ЕСЛИОШИБКА (ВПР ($ B $ 70, данные! $ A $ 2: $ BL $ 249,3, ложь),) 2. = ВПР ($ J 56 долларов США, покупатели! 2 доллара США: 125,8,0 гонконгских долларов) 07.05.2020

Ответы:


1

Хорошо, я видел вашу проблему, вы удаляете все листы, на которые ссылается активный лист в destSpreadsheet, поэтому они не будут доступны, и результаты будут #REF! для каждой ячейки, ссылающейся на эти удаленные листы. Чтобы решить эту проблему, вы можете использовать метод getDisplayValues ​​(). , который извлекает текущее отображаемое значение ячейки вместо getValues(), которое извлекает функцию (в данном случае VLOOKUP), установленную в ячейке. Измените эту строку:

  var sourcevalues = sourceRange.getValues();

Для этого:

  var sourcevalues = sourceRange.getDisplayValues();

Кроме того, не удаляйте другие листы, на которые есть ссылки, пока вы не скопируете значения в destRange в этой строке:

  destRange.setValues(sourcevalues);
08.05.2020
  • Спасибо, проблема заключалась в том, что сначала удалялись данные. 04.06.2020
  • Новые материалы

    Коллекции публикаций по глубокому обучению
    Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

    Представляем: Pepita
    Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

    Советы по коду Laravel #2
    1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

    Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
    Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

    3 способа решить квадратное уравнение (3-й мой любимый) -
    1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

    Создание VR-миров с A-Frame
    Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

    Демистификация рекурсии
    КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..