質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.03%

google apps script フォームの回答取得

解決済

回答 1

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 7,568

ISSHIN

score 10

google apps script を使って
フォームで送られた内容をgmailで送信するという機能実装するためにやっているのですが
いろいろなサイトに載っている以下のコードコピーして使ってもエラーを起こします。
http://ascii.jp/elem/000/000/879/879412/index-3.html

function submitForm(e){
  var itemResponses = e.response.getItemResponses();
  var message = '';
  for (var i = 0; i < itemResponses.length; i++) {
    var itemResponse = itemResponses[i];
    var question = itemResponse.getItem().getTitle();
    var answer = itemResponse.getResponse();
    message += (i + 1).toString() + '. ' + question + ': ' + answer + '\n';
  }
  var address = '☆あなたのGmailアドレスを記入☆';
  var title = 'お問い合わせフォームが送信されました';
  var content = '以下の内容でフォームが送信されました。\n\n' + message;
  GmailApp.sendEmail(address, title, content);
}


なので公式のリファレンスを見てみると以下のコードが書かれていたので
https://developers.google.com/apps-script/reference/forms/form-response

var form = FormApp.openById('フォームのid');
 var formResponses = form.getResponses();
 for (var i = 0; i < formResponses.length; i++) {
   var formResponse = formResponses[i];
   var itemResponses = formResponse.getItemResponses();
   for (var j = 0; j < itemResponses.length; j++) {
     var itemResponse = itemResponses[j];
     Logger.log('Response #%s to the question "%s" was "%s"',
         (i + 1).toString(),
         itemResponse.getItem().getTitle(),
         itemResponse.getResponse());
   }
 }


それを使ってみるとメールは送れたのですが回答のタイトルだけが取得され
中身が取得できません。それで色々コードをいじってログを出してやってみたのですが
自分では解決できませんでした。どなたか、ご教授願いします。
※以下のコードが自分のコードです(いじくりすぎてわかりにくくなっています。すいません。)※

var spreadsheetID = SpreadsheetApp.getActiveSpreadsheet().getId();

function form() {
  var form = FormApp.openById('フォームのid');
  var sheet = SpreadsheetApp.openById(spreadsheetID);
  var tmSheet = sheet.getSheetByName('シート1');
  var Item = form.getItems();
  Logger.log(Item);
  var lastColumn=tmSheet.getDataRange().getLastColumn();//4
  Logger.log(lastColumn);
  var formResponses = form.getResponses();

  var h = formResponses[0];
  Logger.log(h);
  //var l = h.getResponseForItem();
  //Logger.log(l);
  var formlength = formResponses.length;//2
  Logger.log(formlength);//2

 for (var i = 0; i < lastColumn; i++) {
   var formResponse = formResponses[i];
   Logger.log(formResponse);


   var itemResponses = formResponse.getItemResponses();
   Logger.log(itemResponses);
   var itemResponse = itemResponses[i];
   Logger.log(itemResponse);
   var title=itemResponse.getItem().getTitle();
   var answer=itemResponse.getResponse;
   Logger.log(answer);
   Logger.log(title);
   //var title1 = title(1,1);
   var message = '';
   if(title=='名前は?'){
   var username = answer;
   }
   if(title=='今回借りる本の種類は?'){
   var book = answer;
   }
   if(title=='メールアドレス'){
   var mailaddress = answer;
   }
   message +=(i+1).toString()+title+answer;
   //message += (i+1).toString() + '.' +title+'\n';
   Logger.log(message);

   //message = message+answer;
   //Logger.log(message);

 }
  var address = 'isshintakatsusaido@gmail.com';
  GmailApp.sendEmail(address, title, message);
 }

//var itemResponses = formResponse.getItemResponses();
  // var itemResponse = itemResponses[i];
  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正、ベストアンサー選択の依頼

  • kei344

    2016/08/15 01:14

    コードはコードブロックで囲んでいただけませんか? ```(バッククオート3つ)で囲み、前後に改行をいれるか、コードを選択して「</>」ボタンを押すとコードブロックになります。また、参考に下サイトのURLもリンク付きで追記してください。

    キャンセル

回答 1

checkベストアンサー

+2

http://ascii.jp/elem/000/000/879/879412/index-3.html

一番最初に提示されたサンプルコードを試しましたが問題なく動作しました。
私の場合はフォーム画面から(スプレッドシートではなく)スクリプトエディタを起動し、そのサンプルコードをコピペし、適宜自分用に変更し(メールアドレス等)、「リソース」→「現在のプロジェクトのトリガー」と進むと、「トリガーが設定されていません。今すぐ追加するにはここをクリックしてください。」というメッセージが出てくるのでそれをクリックし、保存ボタンを押しました。その後、適当に回答をしたらうまくいきました。それでできると思うのですがどうでしょうか?

エラーが起きた時のメッセージが書かれていると良いのですが。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.03%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる