簡體   English   中英

Google Apps腳本執行API:腳本錯誤消息:找不到腳本功能:【JavaScript】

[英]Google Apps Script Execution API: Script error message: Script function not found:【JavaScript】

我是Web開發的絕對初學者。 我想在我的項目中實現Google Apps Script Execution API。

關於Google Apps腳本執行API,我有兩個問題要問。

(1)我不知道如何解決以下錯誤。

Script error message: Script function not found: make_date_array(month)

盡管我的Google Apps腳本中包含函數“ make_date_array(month)”,但是當我調用google apps執行api時,會出現上述錯誤。 所以我只是不知道該怎么辦。

function send_mail() {
   var date = new Date()
   date.setDate(new Date().getDate())
   date = date.getFullYear() + "-" + zero_padding(date.getMonth() + 1)
   runSingleRowQuery(0, date)
   var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
   var sheet = spreadsheet.getSheetByName("Data");
   var message = "";
   var tmp_message = sheet.getRange(1,1,58 ,2).getValues();

   for(var i = 0;i < tmp_message.length ;i++){
     message +=  tmp_message[i][0] + ":" + tmp_message[i][1] + "<br>"
   }

   MailApp.sendEmail({
       to: 'I put my email address here'
       subject: 'BigQuery',
       htmlBody: message
   });    
} 

function runSingleRowQuery(develop_mode, target_month) {
    // Replace this value with the project ID listed in the Google
    // Developers Console project.
    var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
    var queries_sheet = spreadsheet.getSheetByName("Single row queries");
    var result_sheet = spreadsheet.getSheetByName("Data");

    if(target_month == null){
       var target_month = queries_sheet.getRange(1, 2).getValue();
    }
    make_date_array(target_month);

    result_sheet.getRange(1, 2).setValue(queries_sheet.getRange(1, 2).getValue())
    for (var i = 2; i <= queries_sheet.getLastRow(); i++) {
        var query = queries_sheet.getRange(i, 2).getValue();
        if (query_variation(query) != false) {
            query = query_variation(query)

           Logger.log(queries_sheet.getRange(i, 1).getValue());
           Logger.log("# run query: \n " + query);

        if (develop_mode != 1) {
            Logger.log('\n#####################Run Query#########################');
            var request = {
                query: query
            };
            var queryResults = BigQuery.Jobs.query(request, projectId);
            var jobId = queryResults.jobReference.jobId;

            // Check on status of the Query Job.
            var sleepTimeMs = 500;
            while (!queryResults.jobComplete) {
                Utilities.sleep(sleepTimeMs);
                sleepTimeMs *= 2;
                queryResults = BigQuery.Jobs.getQueryResults(projectId, jobId);
            }

            // Get all the rows of results.
            var rows = queryResults.rows;
            while (queryResults.pageToken) {
                queryResults = BigQuery.Jobs.getQueryResults(projectId, jobId, {
                    pageToken: queryResults.pageToken
                });
                rows = rows.concat(queryResults.rows);
            }
            result_sheet.getRange(i, 2).setValue(rows[0].f[0].v);

            result_sheet.getRange(i, 1).setValue(queries_sheet.getRange(i, 1).getValue());
            result_sheet.getRange(i, 3).setValue(queries_sheet.getRange(i, 3).getValue());
        }
    }
    else {
        result_sheet.getRange(i, 1).setValue(queries_sheet.getRange(i, 1).getValue());
        result_sheet.getRange(i, 2).setValue(queries_sheet.getRange(i, 2).getFormula());
         }
    }
 }

function make_date_array(month) {
    month = month.split('-');
    var last_month = {};
    var more_last_month = {};
    Logger.log((parseFloat(month[0] - 1).toFixed(0)))
    if (parseFloat(month[1] - 1).toFixed(0) < 1) {
        last_month[0] = (parseFloat(month[0]) - 1).toFixed(0);
        last_month[1] = 12;
    } else {
        last_month[0] = (parseFloat(month[0])).toFixed(0);
        last_month[1] = (parseFloat(month[1]) - 1).toFixed(0);
    }
    if (last_month[1] < 10) {
        last_month[1] = '0' + last_month[1];
    }

    if (parseFloat(last_month[1] - 1).toFixed(0) < 1) {
        more_last_month[0] = (parseFloat(last_month[0]) - 1).toFixed(0);
        more_last_month[1] = 12;
    } else {
        more_last_month[0] = (parseFloat(last_month[0])).toFixed(0);
        more_last_month[1] = (parseFloat(last_month[1]) - 1).toFixed(0);
    }
    if (more_last_month[1] < 10) {
        more_last_month[1] = '0' + more_last_month[1];
    }

    date_array['Ym01'] = month[0] + month[1] + '01';
    date_array['last_Ym01'] = last_month[0] + last_month[1] + '01';
    date_array['more_last_Ym01'] = more_last_month[0] + more_last_month[1] + '01';
    date_array['y-m-10_h:s'] = month[0] + '-' + month[1] + '-' + '10 00:00';
    date_array['last_y-m-10_h:s'] = last_month[0] + '-' + last_month[1] + '-' + '10 00:00';
    date_array['more_last_y-m-10_h:s'] = more_last_month[0] + '-' + more_last_month[1] + '-' + '01 00:00';
    date_array['y-m-10'] = month[0] + '-' + month[1] + '-' + '10';
    date_array['last_y-m-10'] = last_month[0] + '-' + last_month[1] + '-' + '10';

    Logger.log(date_array['last_y-m-10'])
}

(2)有人知道我應該如何調用多個函數嗎? 我使用了Google提供的示例代碼。 但是,我不確定我是否遵循正確的方法來調用多個函數。

// Create an execution request object.
    var request = {
        'function': 'send_mail',
        'function': 'runSingleRowQuery(develop_mode, target_month)',
        'function': 'make_date_array(month)',
        };

如果您之前遇到過類似的問題,能否請您幫助解決上述兩個問題? 英語不是我的母語,因此,如果本帖子對您沒有意義或需要更多信息,請留下您的評論。 任何建議將不勝感激。 提前致謝。

除了評論中的鏈接,我認為這段代碼

if(target_month == null){
       var target_month = queries_sheet.getRange(1, 2).getValue();
    }

您必須更改為(no var)

 if(target_month == null){
       target_month = queries_sheet.getRange(1, 2).getValue();
    }

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM