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

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

ただいまの
回答率

88.58%

Googleスプレッドシートで特定の列がある値になったらメールで通知したい

解決済

回答 1

投稿 編集

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

C.Nishimura

score 13

 前提・実現したいこと

Googleスプレッドシートで、
特定の列が「対応済み」に変更されたら、メールで通知したい。

ある依頼をGooleフォームから受け付ける仕組みをとっています。
そのGoogleフォームで入力された値が格納されるGoogleスプレッドシートがあります。
そのシートのある列に、フォームから入力された依頼が対応されたら、
手動で「対応済み」という値を入力します。
その「対応済み」という値に変わったのをトリガーに、
指定のメールアドレス宛に変更された通知を送るようにしたいです。
Google Apps Scriptでの記述方法を教えていただけないでしょうか。
知識が少なく申し訳ないのですが、ゼロから記述いただけますと幸いです。

 試したこと

https://teratail.com/questions/65372
上記のご質問にも似ているのですが、slackではなく、メール通知にしたいです。
また、
https://qiita.com/3mc/items/b78cbb4c2eebf06d26a0
これにも似ているのですが、トリガーの設定のせいか、
全く同じスプリプトを入れて(配信先のメールなどだけ調整して)もうまくメールが飛びませんでした。

 補足

通知メールの内容は、スプレッドシートの下記の値を使いたいです。
A列:タイムスタンプ(フォームからの依頼日時)
C列:依頼者名
S列:「対応済み」という項目を入れる列
メール文面
「A(フォームからの依頼日時)にCさんから依頼の案件が対応済みになりました」

  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

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

  • C.Nishimura

    2018/10/30 18:16

    >dice142 さま 不明瞭で失礼いたしました。qiita記事のそのままで使ってみたのですが、トリガーなどの設定が不備だったのか、メールが通知が全く送られてきませんでした。

    キャンセル

  • C.Nishimura

    2018/10/30 18:17

    >papinianus さま 回答ありがとうございました。書き方が不明瞭で失礼いたしました、ご指摘のとおり、両方yesで相違ございません。

    キャンセル

  • dice142

    2018/10/30 18:26

    Logger.logでログ確認して、まず関数自体が呼ばれているのかを確認し、呼ばれているのであればメール通知のコード直前はどうかなど確認してください。

    キャンセル

回答 1

checkベストアンサー

+2

権限の都合がありますので、トリガーを設定してください。
(トリガーの設定方法は調べてください。設定値は、onEdit、スプレッドシートから、編集時、の3つです
(分かるとは思いますが「フォームの回答」とか、宛先のアドレスとかはお使いの環境にあわせてください

function onEdit(e) {
  const workingSheet = e.range.getSheet();
  if(workingSheet.getSheetName() !== "フォームの回答" || e.value !== "対応済み") {return;}
  const formValue =  workingSheet.getRange(e.range.getRow(), 1, 1, 3).getValues()[0];
  MailApp.sendEmail({to:"someone@example.com" , subject:"依頼者("+formValue[2]+")", body:"依頼時刻("+formValue[0]+")\n対応済み" });
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/10/30 18:22

    説明不明瞭の中、ありがとうございます。
    いただいたscriptで無事、やりたかったことを実装できました。
    ありがとうございました。

    キャンセル

  • 2018/10/30 19:12 編集

    他の質問者様に比べて不明瞭ということはないです。が、2つお願いがあります。
    ・参照資料はすべてリンクにしてください、Qiitaは気づきませんでした。
    ・そのQiita記事は参考にしないでください。

    解決してよかったです

    キャンセル

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

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

同じタグがついた質問を見る