背景
- Googleフォームは便利ですが、標準の設定だと指定した時間に回答受付を開始したり締め切ることができません(2022年11月14日現在)。手動でもいいじゃんと思うかもしれませんが、最近気になっていたGoogle Apps Script(GAS)の勉強にもなると思い、色々調べて自動化に取り組みました。
- GASとは、Google社が提供するプログラミング言語です(JavaScriptベースの言語のようです)。Googleのアカウントさえあれば使うことができます。
やりたいこと
- 指定した時間に回答の受付を自動で開始する
- 回答の受付を開始したら、通知のメール(開始の知らせ)を受信する
- 指定した時間に回答の受付を自動で締め切る
- 回答の受付を締め切ったら、通知のメール(締め切った知らせ + 回答確認ページへのリンク)を受信する
やり方
1. 自動化したいGoogleフォームを開き、【送信】の右隣りの点(【その他】)をクリックする(この時点で回答の受付を締め切っておきます)。
2. 【<>スクリプトエディタ】をクリックします。
3. 現在表示されているコードを削除し、以下のコードを張り付けてください。"メールを受け取りたいメールアドレス"の箇所を変更してください。
- 名前(無題のプロジェクトと表示されている箇所)は変えなくても変えてもどちらでもいいです。
// 自動で受付を開始するプログラム
function openForm() {
const form = FormApp.getActiveForm();
form.setAcceptingResponses(true);
const formName = form.getTitle()
const recipient = "メールを受け取りたいメールアドレス"
const subject = "\"" + formName + "\""
const body = "\"" + formName + "\"" + " just has opened."
GmailApp.sendEmail(recipient, subject, body)
}
// 自動で受付を締め切るプログラム
function closeForm() {
const form = FormApp.getActiveForm();
form.setAcceptingResponses(false);
const formName = form.getTitle()
const url = form.getEditUrl() + "#responses"
const recipient = "メールを受け取りたいメールアドレス"
const subject = "\"" + formName + "\""
const body = "\"" + formName + "\"" +" has just closed.\nCheck the URL below\n" + url
GmailApp.sendEmail(recipient, subject, body)
}
4. 問題なく作動するかテストする
- まず、自動で受付を開始するプログラム(openForm)が作動するかを確かめます。【実行ログ】の左が"openForm"になっているかを確認し、【実行】を押します。
-
次に、自動で受付を締め切るプログラム(closeForm)が作動するか確認します。【実行ログ】の左を"closeForm"に変更し(下矢印ボタンを押して選ぶ)、【実行】を押します。権限承認の画面はもう出ません。
5. 実行する時間を選択する
-
テストが無事に完了したら、実際に実行するために機能を設定します。画面の左端に目覚まし時計のマーク(【トリガー】)があるので、それをクリックします。
-
実行テストと同じように、"openForm"と"coloseForm"の両方を設定します。まずは"openForm"からです。【実行する関数を選択】で"openForm"を設定。【イベントのソースを選択】で【時間主導型】を選択します。【時間ベースのトリガーのタイプを選択】で【特定の日時】を選択します。日時を指定したら忘れずに保存してください。
-
画面のようにトリガーが追加されています。次に、"closeForm"を設定します。【+ トリガーの追加】を押して、【実行する関数を選択】で"closeForm"を設定。あとのやり方は"openForm"と同じです。
実行結果
-
以下の2通のメールを受信できました。
-
受付開始時
-
受付終了時
注意すること
時間の誤差
- 設定した時間に命令を実行しますが、実行時間に誤差があると報告している記事がありました(こちら)。Googleフォームを配布する際には、5分くらいの余裕を持たせて時間を設定する方がよいかもしれません。
メール送信の上限
- 無料のGoogleアカウントの場合、GASを使って送信できるメールの数が1日100件という上限があります。Google Workspaceだと1500件送信できるようです。以下のスクリプトであとどれくらい送信できるのかを確認できます。
function myFunction(){
Logger.log(MailApp.getRemainingDailyQuota())
}
- 僕の場合、あと79通のメールを本日送れるようです。
最後に
- 「GASを使ったこんな便利なことできるよ!」もしくは「こんなことできませんか?」という意見があればコメント欄で是非共有していただけると幸いです。
参考資料
書籍
- GoogleAppsScript実践プログラミング(GASについて)
ウェブサイト
- Googleフォームを自動で受付終了にする方法 (時間指定・件数指定) (プログラム)
- Googleフォームを朝の時間だけ受け付けたい。自動で回答の開始・締切時間を設定する方法。(プログラム)
- Googleフォームの回答受付と閉鎖を時間指定する方法を知ろう! (実行開始時間の誤差)
- GASのメール送信は実行上限に注意!残り回数確認と上限以上のメールを送る方法 (メール送信の上限と確認プログラム)