PolarBearGG
@PolarBearGG
I know that I know nothing

Где проблема в скрипте?

Почему когда загружает этот скрипт в таблице не все сайты работают постоянно есть несколько с ошибками при том что рандомно?
https://gist.github.com/csarigoz/76777a4743bfa8bed491
spoiler
/**
 * Returns Mobile Speed & Optimization and Desktop Speed & Optimization values in six adjacent columns
 * by Cagri Sarigoz
 */
function checkAll(Url) {

    //CHANGE YOUR API KEY WITH YOUR_API_KEY BELOW
    var key = "YOUR_API_KEY";
    var serviceUrlMobile = "https://www.googleapis.com/pagespeedonline/v4/runPagespeed?url=" + Url + "&strategy=mobile&key=" + key;
    var serviceUrlDesktop = "https://www.googleapis.com/pagespeedonline/v4/runPagespeed?url=" + Url + "&strategy=desktop&key=" + key;
    //    var serviceUrlMobileFriendliness = "https://searchconsole.googleapis.com/v1/urlTestingTools/mobileFriendlyTest:run?fields=mobileFriendliness&key="+key;
    //    var formDataMobileFriendliness = {'url':Url};
    //    var optionsMobileFriendliness = {
    //     'method' : 'post',
    //     'payload' : formDataMobileFriendliness
    //    };
    var array = [];

    if (key == "YOUR_API_KEY")
        return "Please enter your API key to the script";


    var responseMobile = UrlFetchApp.fetch(serviceUrlMobile);

    if (responseMobile.getResponseCode() == 200) {
        var contentMobile = JSON.parse(responseMobile.getContentText());

        if ((contentMobile != null) && (contentMobile["ruleGroups"] != null)) {
            if (contentMobile["responseCode"] == 200) {
                var optimizationScoreMobile = contentMobile["ruleGroups"]["SPEED"]["score"];
                if ("metrics" in contentMobile["loadingExperience"]) {
                    var avgFCPMobile = ((contentMobile["loadingExperience"]["metrics"]["FIRST_CONTENTFUL_PAINT_MS"]["median"]) / 1000).toFixed(1).toString() + " (" + contentMobile["loadingExperience"]["metrics"]["FIRST_CONTENTFUL_PAINT_MS"]["category"] + ")";
                    var avgDCLMobile = ((contentMobile["loadingExperience"]["metrics"]["DOM_CONTENT_LOADED_EVENT_FIRED_MS"]["median"]) / 1000).toFixed(1).toString() + " (" + contentMobile["loadingExperience"]["metrics"]["DOM_CONTENT_LOADED_EVENT_FIRED_MS"]["category"] + ")";
                } else {
                    var avgFCPMobile = "Unavailable";
                    var avgDCLMobile = "Unavailable";
                }
            } else {
                var optimizationScoreMobile = "An error occured";
                var avgFCPMobile = "An error occured";
                var avgDCLMobile = "An error occured";

            }
        }
    }

    var responseDesktop = UrlFetchApp.fetch(serviceUrlDesktop);

    if (responseDesktop.getResponseCode() == 200) {
        var contentDesktop = JSON.parse(responseDesktop.getContentText());

        if ((contentDesktop != null) && (contentDesktop["ruleGroups"] != null)) {
            if (contentDesktop["responseCode"] == 200) {
                var optimizationScoreDesktop = contentDesktop["ruleGroups"]["SPEED"]["score"];
                if ("metrics" in contentDesktop["loadingExperience"]) {
                    var avgFCPDesktop = ((contentDesktop["loadingExperience"]["metrics"]["FIRST_CONTENTFUL_PAINT_MS"]["median"]) / 1000).toFixed(1).toString() + " (" + contentDesktop["loadingExperience"]["metrics"]["FIRST_CONTENTFUL_PAINT_MS"]["category"] + ")";
                    var avgDCLDesktop = ((contentDesktop["loadingExperience"]["metrics"]["DOM_CONTENT_LOADED_EVENT_FIRED_MS"]["median"]) / 1000).toFixed(1).toString() + " (" + contentDesktop["loadingExperience"]["metrics"]["DOM_CONTENT_LOADED_EVENT_FIRED_MS"]["category"] + ")";
                } else {
                    var avgFCPDesktop = "Unavailable";
                    var avgDCLDesktop = "Unavailable";
                }
            } else {
                var optimizationScoreDesktop = "An error occured";
                var avgFCPDesktop = "An error occured";
                var avgDCLDesktop = "An error occured";

            }
        }
    }

    //    var responseMobileFriendliness = UrlFetchApp.fetch(serviceUrlMobileFriendliness, optionsMobileFriendliness);
    //    var contentMobileFriendliness = JSON.parse(responseMobileFriendliness.getContentText());
    //      
    //      if ( (contentMobileFriendliness != null) && (contentMobileFriendliness["mobileFriendliness"] != null) )
    //      {
    //        var mobileFriendliness = contentMobileFriendliness["mobileFriendliness"];
    //      }
    //      else
    //        {
    //          var mobileFriendliness = "An error occured";
    //        }

    var currentDate = new Date().toJSON().slice(0, 10).replace(/-/g, '/');

    array.push([avgFCPMobile, avgDCLMobile, optimizationScoreMobile, avgFCPDesktop, avgDCLDesktop, optimizationScoreDesktop, currentDate]);
    Utilities.sleep(1000);
    return array;

}
  • Вопрос задан
  • 81 просмотр
Пригласить эксперта
Ответы на вопрос 1
oshliaer
@oshliaer Куратор тега Google Apps Script
Google Products Expert
Потому что вы выбираете квоту запросов на свой ключ. Посмотрите статистику запросов в консоли разработчика.

Вот этот Utilities.sleep(1000); как мертвому припарка.

Если вы запускаете скрипт как пользовательскую формулу, то вам нужно делать последовательные вызовы

5d9bad1a8c877535631892.png

Пример принципа в Таблице
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы