0

スクリプトを使用して、フォームが送信されるたびにフォームの結果を電子メールで送信しています。コード全体は、次のGoogleグループに投稿されています。

http://groups.google.com/a/googleproductforums.com/d/topic/apps-script/1rObNfuez6k/discussion

現在のコードは次のとおりです。

function contactUsMailer2(e) {

//    var ss = SpreadsheetApp.getActive();
//    SpreadsheetApp.setActiveSpreadsheet(ss);

    var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Data'); //default sheets - change if you
    var setup = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Setup'); //rename the sheets

    var width = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Data').getLastColumn(); //get "width" of sheet, used to enumrate fields
    var myEmailAddress = setup.getRange('B3').getValue(); //get email recipient(s) from "Setup" (default)
    var myEmailSubject = setup.getRange('B4').getValue(); //get a subject line from "Setup" (default)
                                                          //from row 1 of "Data"
    var sheetURL = SpreadsheetApp.getActiveSpreadsheet().getUrl(); //get sheet url to include in email
    var formURL = SpreadsheetApp.getActiveSpreadsheet().getFormUrl(); //get form url to include in email

    var column = 'A';
    var message = ''; 
    var htmlBody = '<html><body><table>'; //generated email will have both an HTML table and a plain-text part
                                          //to be RFC compliant.  beginning of html and table.
    for (var c=1; c<=width; ++c) {
        var data = sheet.getRange(1, c, 1, 1).getValue(); //this gets the "filed" names from the 1st row of "Sheet1"

        try {      
            //retrieve field data and build the HTML and plain-text emails
            var message = message + data + ': ' + e.namedValues[data].toString() + '\r\n'; //plain-text
            var htmlBody = htmlBody + '<tr><td><b>' + data + ': </b></td><td>' + e.namedValues[data].toString() + '</td></tr>'; //HTML
        }
        catch (a) {
            var message = message + data + ': n/a\r\n';
            var htmlBody = htmlBody + '<tr><td><b>' + data + ': </b></td><td>n/a</td></tr>';
        }

        var column = String.fromCharCode(column.charCodeAt() + 1); //increment column letter
    }

    var htmlBody = htmlBody + '</table>'; //close table

    var message = message + '\r\n\r\nData from form located at ' + formURL + '\r\n'; //put form url in text email
    var message = message + 'Data posted to spreadsheet at ' + sheetURL; //put sheet url in text email

    var htmlBody = htmlBody + '<br><br>Data from form located <a href=\"' + formURL + '\">here</a><br>'; //put form url in HTML email
    var htmlBody = htmlBody + 'Data posted to spreadsheet <a href=\"' + sheetURL + '\">here</a><br>'; //put sheet url in HTML email
    var htmlBody = htmlBody + '</body></html>'; //close html

    MailApp.sendEmail(myEmailAddress, myEmailSubject, message, {htmlBody: htmlBody}) ; //send the email
}

function showid() {
    Browser.msgBox("The sheet ID is:\r\n\r\n" + SpreadsheetApp.getActiveSpreadsheet().getId());
}

スクリプトは元のスプレッドシートで正常に機能するようになりましたが、新しいフォームとスプレッドシートでスクリプトを使用しようとすると、電子メールを送信できません。フォームはスプレッドシートに問題なく入力され、スプレッドシートが更新されたことを示す通常の電子メールが届きますが、スクリプトの電子メールは届きません。

面白いことに、スクリプトをデバッグすると、電子メールが送信され、すべてのフィールドにnullエントリが送信されます(これは私が期待することです)。デバッグは、スクリプト自体のエラーを報告しません。私は何が欠けていますか?

4

3 に答える 3

1

新しいフォームでスクリプトを承認しましたか?スクリプトは電子メールを送信する必要があるため、明示的な承認が必要です。

于 2012-05-18T05:13:19.067 に答える
0

周りの引用を削除してみてください for (var c=1; c<=width; ++c) { var data = sheet.getRange(column + '1').getValue(); //this gets the "filed" names from the 1st row of "Sheet1"

私はスクリプトで同様のことをします、そして以下は私のために働きます。

var rangeval = "B"+(i+1); var nameFld = filesheet.getRange(i+1,1).getValue();

ジョー

于 2012-05-17T21:12:39.203 に答える
0

トリガーが「送信時」に設定されていることを確認してください。鉱山は「オープン時」に設定されました。

于 2012-05-18T18:07:07.983 に答える