Spreadsheet.flush не работает должным образом в моем скрипте Google Apps - PullRequest
0 голосов
/ 05 ноября 2019

Вот мои 2 электронные таблицы:

Gsheet1: Googlesheet для репликации (изменится только № сотрудника и имя сотрудника)

Gsheet2: лист конфигурации (содержит № сотрудника, имя сотрудника, репликациюстатус, ссылка pubHTML), которая будет указывать номер сотрудника и имя сотрудника в Gsheet1

. Таким образом, у меня есть этот код со следующими функциями:

  1. Реплицировать Gsheet1 в зависимости от количества сотрудников (В настоящее время у меня более 800 сотрудников) на Gsheet2 и выгрузите его в папку на диске Google.
  2. после репликации установит для «завершенного» состояния репликации значение Gsheet2.
  3. Измените свойства редакцииреплицируйте лист и сделайте его опубликованным в Интернете.
  4. Получите ссылку опубликованного Интернета (pubhtml) и поместите ее в столбец ссылок Gsheet2 pubHTML.

Что происходит, когда я пытаюсьlogger.log Результаты этого кода ниже, при условии, что у меня есть 2 записи на моем Gsheet2, он зацикливается три раза, первая и третья запись в циклеодинаковы.

  var TemplatesFromDrive = DriveApp.getFolderById(SpreadsheetApp.getActive().getSheetByName("Master Config").getRange("B2").getValue()).getFiles();
  while (TemplatesFromDrive.hasNext()) {
    var File = TemplatesFromDrive.next();
    Logger.log(File.getName());

Я думал, что это из-за Spreadsheet.flush (), который мне не хватает. Где лучшее место, где я могу поместить его в свой код, чтобы мой цикл работал правильно? Ниже мой полный код.

function replicateCards() {
    var ss = SpreadsheetApp.openById('Gsheet2-xxxx');
    var copyCard = SpreadsheetApp.openById('Gsheet1-xxxx');
    var getID = DriveApp.getFileById(copyCard.getId())
    var card = copyCard.getSheetByName("Card");
    var mastersheet = ss.getSheetByName("Mastersheet");
    var employeeNumber2 = ss.getRange("A2:A").getValues;
    var getLastRow = mastersheet.getLastRow();
    var destinationFolder = DriveApp.getFolderById('googledrivefolder-xxx');
    var changeColorToGrayList = card.getRangeList(['C7', 'E7', 'G7', 'I7', 'K7', 'M7', 'O7', 'Q7',
        'C9', 'E9', 'G9', 'I9', 'K9', 'M9', 'O9', 'Q9',
        'C11', 'E11', 'G11', 'I11', 'K11', 'M11', 'O11', 'Q11']);
    var setValueToZero = card.getRangeList(['C8', 'E8', 'G8', 'I8', 'K8', 'M8', 'O8', 'Q8',
        'C10', 'E10', 'G10', 'I10', 'K10', 'M10', 'O10', 'Q10',
        'C12', 'E12', 'G12', 'I12', 'K12', 'M12', 'O12', 'Q12']);
    for (i = 1; i < getLastRow; i++) {
        var badgeStatus = mastersheet.getRange(i + 1, 5).getValue();
        if (badgeStatus == "") {
            var employeeNumber = mastersheet.getRange(i + 1, 1).getValue();
            var employeeName = mastersheet.getRange(i + 1, 2).getValue();
            copyCard.getRange("H3").setValue(employeeNumber);
            copyCard.getRange("C3").setValue(employeeName);
          SpreadsheetApp.flush();
            getID.makeCopy(employeeNumber, destinationFolder);
            mastersheet.getRange(1 + i, 5).setValue("completed");
          SpreadsheetApp.flush();
            var files = DriveApp.getFolderById(SpreadsheetApp.openById("Gsheet1-xxxx").getSheetByName("Config Sheet").getRange("B1").getValue()).getFiles();
            while (files.hasNext()) {
                var file = files.next();
              Logger.log(file.getName());
                var Found = false;
                for (var j = 0; j < employeeNumber2.length; i++) {
                    if (employeeNumber2[j][0] == file.getName()) {
                        Found = true;
                    }
                }
                if (Found) {
                    continue;
                }
                try {
                    var fileId = file.getId();
                    var fileName = file.getName();
                    var revisions = Drive.Revisions.list(fileId);
                    var lastRevisionId = revisions.items[revisions.items.length - 1].id;
                    // get the resource and set the publish parameters
                    var resource = Drive.Revisions.get(fileId, lastRevisionId);
                    //       Logger.log(resource);
                    resource.published = true;
                    resource.publishAuto = true;
                    resource.publishedOutsideDomain = true;
                    // publish to the web
                    Drive.Revisions.update(resource, fileId, lastRevisionId);
                  SpreadsheetApp.flush();
                    var openByID = SpreadsheetApp.openById(fileId);
                  SpreadsheetApp.flush();
                    var googleDriveSheet = openByID.getUrl().replace("edit", "pubhtml"); // or replace("edit", "pub");
                  SpreadsheetApp.flush();
                    mastersheet.getRange(1 + j, 9).setValue(googleDriveSheet);
                  SpreadsheetApp.flush();

                } catch (err) {
                    Logger.log(err);
                }
            }
        }
    }
}

1 Ответ

0 голосов
/ 05 ноября 2019

Измените var getLastRow = mastersheet.getLastRow(); на var getLastRow = mastersheet.getLastRow()-1;

Причина в том, что вы начали получать данные из второго ряда. Если вы начнете с третьего, вы должны сделать var getLastRow = mastersheet.getLastRow()-2; ...

...