こちらの記事のアップデート版です。
Googleフォームで回答されたときに、LINEで回答内容を確認できるものを作ります。
使うもの
- Googleフォーム
- Google Apps Script (GAS)
- LINE Notify
LINE Notify の設定
こちらから LINE Notify にアクセス
右上のログインから、LINEアカウントでログイン
data:image/s3,"s3://crabby-images/decf1/decf1752c75cc1e6bf33ba28d415cb48d20547a6" alt=""
ログインできると、右上がアカウント名(名前)になるので、アカウント名の部分をクリック→「マイページ」をクリック
data:image/s3,"s3://crabby-images/553e0/553e0aa4901a098f76b7f6fbec9b19eb3c85f5bb" alt=""
画面下の「トークンを発行する」をクリック
data:image/s3,"s3://crabby-images/b38bc/b38bc3fd5bc273a7adb75a42e0714ee28ec3cde9" alt=""
「①トークン名」は通知する際に表示される名前です。
「②トークルーム」で通知するLINEグループを選択してください。一番上の「1:1でLINE Notifyから通知を受け取る」を選択すると、「LINE Notify」のアカウントから通知が届きます。
「③発行する」をクリックして、トークンを発行します。
data:image/s3,"s3://crabby-images/afcc9/afcc9ab4948cb82d1238800d9bb84df3b44ffe49" alt=""
次の画面でトークンが表示されるので、忘れないようにコピーしておく!
data:image/s3,"s3://crabby-images/bf525/bf5256dc6eac55df1d8fd7e91e9cc37601055a45" alt=""
「LINE Notify」から「Personal Access Tokenを発行しました。」と通知が届きます。
data:image/s3,"s3://crabby-images/62147/621474e73dc557f6658d513cd981381b0b04eeeb" alt=""
通知を送るLINEグループに「LINE Notify」が招待されていない場合は、以下の通知が届きます。LINEグループに「LINE Notify」を追加しておきましょう。
data:image/s3,"s3://crabby-images/54e49/54e49557a599ec119d089a7d54bec20dc7c8b59e" alt=""
Googleフォームの設定
今回は例として、以下のようなフォームを作成します。
data:image/s3,"s3://crabby-images/af4b5/af4b5375225fb9ebdd630e2a2ba9c98cbb650224" alt=""
「回答」のタブから「スプレッドシートにリンク」をクリックして、スプレッドシートを作成する
data:image/s3,"s3://crabby-images/88a4c/88a4c321e013798b5866dcec03acf13a18e62f3f" alt=""
「新しいスプレッドシートを作成」にする。必要に応じてスプレッドシートの名前を変更する。
data:image/s3,"s3://crabby-images/0a63e/0a63e83affdc355b354190d87ee7d505d0b8a9a0" alt=""
GASの設定
スプレッドシートが開いたら、「拡張機能」→「Apps Script」をクリック
data:image/s3,"s3://crabby-images/d4cab/d4cabce1c228c39a340767dd675a3ebfd304242a" alt=""
デフォルトで記述されているコード(function myFunction()~~)をすべて消して、以下のコードをコピペする。
「{LINE_TOKEN_xxxxxxxx}」の部分に「LINE Notify」の設定時にコピーしたトークンを貼り付ける。最後に「Ctrl+S」で保存。
//spreadsheetからデータを取得
function GoogleFormToLine(){
const sheet = SpreadsheetApp.getActiveSheet(); //sheetの指定
const row = sheet.getLastRow(); //行数
const column = sheet.getLastColumn(); //列数
const range = sheet.getDataRange(); //sheetから範囲指定するための準備
let message = "";
for(i=1;i<=column;i++){
const item = range.getCell(1, i).getValue(); //1行目
let value = range.getCell(row, i).getValue(); //最終行
if(item == "タイムスタンプ"){ //タイムスタンプを見やすくする
value = Utilities.formatDate(value,"JST","yy/MM/dd(E) HH:mm:ss");
}
message += "\n■"+item+"\n"+value;
}
SendToLine(message);
}
//LINEに通知
function SendToLine(message){
const token = PropertiesService.getScriptProperties().getProperty('LINE_TOKEN');
const op =
{
"method" : "post",
"Content-Type" : "application/x-www-form-urlencoded",
"payload": "message=" + message,
"headers":{"Authorization" : "Bearer " + token}
};
const res = UrlFetchApp.fetch("https://notify-api.line.me/api/notify",op);
Logger.log(JSON.parse(res.getContentText())); //Response
}
//Tokenを登録する
//1回実行したら、以下のコードを削除する
function RegisterToken(){
const LINE_TOKEN = "LINE_TOKEN_xxxxxxxx" //ここにLINE_TOKENを入力する
PropertiesService.getScriptProperties().setProperty('LINE_TOKEN',LINE_TOKEN);
}
上のメニューバーの部分で「①GoogleFormToLine」をクリックして「②RegisterToken」を選択し、「③実行」をクリック
data:image/s3,"s3://crabby-images/19d4f/19d4f7ec23484da365a157d11a324623cbefb882" alt=""
「承認が必要です」の画面が出てきたら「権限を確認」をクリック。次にGoogleアカウントへのログインを求められる場合があるので、ログインする。
data:image/s3,"s3://crabby-images/628fe/628fe8c65ec16f1fe3c7ba044efd843623a3d647" alt=""
「このアプリはGoogleで確認されていません」と表示されるので、左側の詳細をクリック
※「安全なページに戻る」をクリックすると、先に進めません。
data:image/s3,"s3://crabby-images/0468d/0468d43a36808f7b54f487b01ca68288a9ce6be7" alt=""
さらに左下の「xxx(安全ではないページ)に移動」をクリック
data:image/s3,"s3://crabby-images/01dc1/01dc1225e2463e8cd134b09c9800359bfd578dbd" alt=""
Googleアカウントへのアクセスを許可するか表示されるので、右下の「許可」をクリック
※プログラム(GAS)がGoogle内部のデータにアクセスすることを承認するかの画面です。プログラムに不正なコードが混入している場合には、情報漏えいのリスクがあります。
data:image/s3,"s3://crabby-images/911ef/911ef0ab8c47b63781cd9ef77ee4d201411debd4" alt=""
以下のように実行ログが出ていれば、LINE_TOKENが登録できているはずです。
※エラーが出たら、コピペしたコードに間違いがないか、手順通りにしたか確認しましょう。
data:image/s3,"s3://crabby-images/20fa4/20fa4cc9b9af005ebb675667425f6f997ab9097d" alt=""
LINE_TOKENが登録できたら、以下のコード部分は不要なので、削除しておきましょう。
※LINE_TOKENをコードに書きっぱなしにするのはよくないです。
//Tokenを登録する
//1回実行したら、以下のコードを削除する
function RegisterToken(){
const LINE_TOKEN = "{LINE_TOKEN_xxxxxxxx}" //ここにLINE_TOKENを入力する
PropertiesService.getScriptProperties().setProperty('LINE_TOKEN',LINE_TOKEN);
}
最後にフォームに回答された時にプログラムを実行するため、トリガーの設定をします。時計マークのアイコンをクリック→右下の「トリガーを追加」をクリック
data:image/s3,"s3://crabby-images/fc8ea/fc8ea897cb70e58860b842494c076f6dcc39324c" alt=""
以下のように設定する。
- 実行する関数:GoogleFormToLine
- 実行するデプロイ:Head
- イベントのソース:スプレッドシートから
- イベントの種類:フォーム送信時 (デフォルトとは違うので注意)
- エラー通知設定:どれでもよい(エラーがあったときに通知を受け取る頻度)
data:image/s3,"s3://crabby-images/791eb/791eb01e7d61cb7eab74aa2ca6d390eaa1205584" alt=""
再度、Googleアカウントへのログインと、アプリの認証画面が出てくると思うので、前述と同じように操作する。
動作確認
例えば、以下の内容でフォームを送ってみる。
data:image/s3,"s3://crabby-images/a8eee/a8eee8ed8721607e55cfe8ffbe3ad9206bbdc5ab" alt=""
きちんと届くと思います。
data:image/s3,"s3://crabby-images/03b60/03b60cd730c136a0116fd6a6b9fbc64d77f5d987" alt=""