7
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Google Forms

説明不要かもしれませんが、Google Formsとは『Google』が無料で提供してくれているメールフォームサービスです。

オンライン フォームやアンケートを簡単に作成して共有し、回答をリアルタイムで分析できます。

公式サイトのファーストビューに記載している通り、イベントの告知や募集、アンケート調査など幅広く活用できます。

Google アカウントがあれば手軽に利用できるので、昨今のローコード・ノーコードの流れもあって非エンジニアの方々も使われている印象です(何より操作が直感的で簡単ですしね)。

今までだと独自のメールフォームを都度用意・設定しなくてはならなかったところが手軽に実装できるので、筆者も実務で何度か使用しています。

今回は、筆者が実務の中で少し手間取った差出人名と送信元メールアドレスの調整を Tips(自身の備忘録)として皆様と共有できればと記事を書いていこうと思います!

自身のGアカウントを使うと差出人は自分になる

「何を当たり前のことを……」という話なのですが、筆者が実務で利用する際は自身の(ビジネス用)アカウントで行いました。
本来は会社・事業所からの情報発信などを担う部分は、その会社・事業所で用意した企業アカウントを用意・利用すべきです。釈迦に説法ですね。

しかし筆者の所属する会社では「なる早で、いい感じにやっといて!」というスタイルが多く……、それでも本来はしっかり説得や説明なりをして企業アカウントを作って進めるべきなのですが、納期が厳しかったりして自身のアカウントで行うことに(良い子はマネしないで!)。

そこでフォームを用意してGASで自動返信機能も実装し、いざ送信テストを行った際に……
「差出人が自分じゃん!!」と(当たり前のことに)驚きました。

下記の「sendernameには事業所名、senderadressには当該メールアドレスを記入しているのに何故だ?」と、恥ずかしながら原因が自身のアカウントを使っているからということに中々気づけませんでした。

.
.
var sendername = "差出人名";
var senderadress = "example.mail@gmail.com";
.
.

Gmailにおける設定で当該メールアドレスをエイリアスに追加する

Gmail のヘルプに書いてあるように、別のメールアドレスを所有している場合は、そのアドレスを使用してメールを送信できます。Gmail以外も可能です。

スクリーンショット 2023-12-03 161847.png

手順まで書いてくれていて丁寧ですね。

とはいえ、文字ではなくスクリーンショットなど参照付きで設定を進めたい場合もあるかと思います。
その場合は、下記のサイト様がすごくわかりやすかったです。

これで無事に希望する差出人名と当該メールアドレスが自動返信メールに記載されていました!

筆者が利用したGASの記述(自動返信機能を含む)を念のため書き残しておきます。
下記サイト様の記事を参考にさせていただきました。

下記GAS使用時、Google Formsの設定(スクリプトエディタのスクリプトの発動タイミング)においてトリガーの設定で「フォーム送信時」を指定してください。

function sendMailGoogleForm() {
    Logger.log('sendMailGoogleForm() debug start');

    /**
     * 設定エリアここから
    */

    var subject = "[お問い合わせありがとうございます]" // 件名
    var body = "ここからメール本文を記載。【\n】は改行コード。\n\n"
        + "--------------------------------------------------------------------------------\n";
    var footer = "---------------------------------------------------------------------------------\n\n"
        + "XXXXX\n(株式会社 XXXXX xxxx部)\n〒123-4567 XX県YY市ZZ町99-9-9\nTEL 0120-12-1234/FAX 0120-34-5678\nEmail:info@hoge.net\nURL:http://example.com"; // フッター(署名)

    // 入力カラムの指定(※ 制作した Google Form の該当項目名と【全く同じ記述】にしないと機能しないので注意)
    var NAME_COL_NAME = '名前'; // Google Form の該当項目名を「名前」にする。
    var MAIL_COL_NAME = 'メールアドレス'; // Google Form の該当項目名を「メールアドレス」にする。

    // メールの送信先
    var admin = "info@hoge.net, personal.foo@piyo.co.jp"; // 管理者(必須)、複数指定も可
    var sendername = "株式会社 XXXXX xxxx部からのお知らせです(担当:XXX YYY)"; // 送信者名(必須)
    var senderadress = "info@hoge.net"; // 送信者アドレス(*1)
    var cc = ""; // cc
    var bcc = admin; // bcc
    var reply = admin; // Reply-To: デフォルトはvar bcc = admin;
    var to = ""; // To: (入力者のアドレスが自動的に反映される)

    /**
     * 設定エリアここまで
    */

    try {
        // スプレッドシート関連
        var sheet = SpreadsheetApp.getActiveSheet();
        var rows = sheet.getLastRow();
        var cols = sheet.getLastColumn();
        var rg = sheet.getDataRange();
        Logger.log("rows=" + rows + " cols=" + cols);

        // メール件名・本文の作成と、送信先メールアドレスの取得
        for (var i = 1; i <= cols; i++) {
            var col_name = rg.getCell(1, i).getValue(); // カラム名
            var col_value = rg.getCell(rows, i).getValue(); // 入力値
            if (col_name === "タイムスタンプ") {
                continue; // カラム名が"タイムスタンプ"の時は処理を飛ばす
            }
            body += "[" + col_name + "] \n";
            body += col_value + "\n\n";
            if (col_name === NAME_COL_NAME) {
                body = col_value + "\n\n" + body;
            }
            if (col_name === MAIL_COL_NAME) {
                to = col_value;
            }
        }
        body += footer;

        // 送信先オプション
        var options = { name: sendername, from: senderadress }; // *1:オブジェクトとして指定(別アドレスを使用する場合は前提としてエイリアスの登録・承認作業が必要)
        if (cc) options.cc = cc;
        if (bcc) options.bcc = bcc;
        if (reply) options.replyTo = reply;

        // メール送信関連 
        if (to) {
            GmailApp.sendEmail(to, subject, body, options);
        } else {
            GmailApp.sendEmail(admin, "【失敗】 Googleフォームにメールアドレスが、指定されていません", body);
        }
    } catch (e) {
        GmailApp.sendEmail(admin, "【失敗】 Googleフォームからメール送信中にエラーが発生", e.message);
    }
}

さいごに

Gmail しかり、Google Formsはもはや web 界隈に限らず、個人で活躍される幅広い方々(ハンドメイド作家やイラストレーター、コンサルタントなど)にも利用されていると思います。
筆者が多くのネット記事に助けられているように、この記事がどなたかのお役に立てれば嬉しい限りです。
ここまで読んでいただき、ありがとうございました。

参考情報

7
4
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
7
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?