Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
LINE Notifyで作る健康習慣をサポートする仕組み
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
tadaken3
December 06, 2019
Programming
2.2k
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
LINE Notifyで作る健康習慣をサポートする仕組み
tadaken3
December 06, 2019
More Decks by tadaken3
See All by tadaken3
Exploratoryサーバーで構築した 戦略と実行を繋ぐSSoT分析環境
tadaken3
0
31
kubell 2025 エンジニアサマーインターンシップ
tadaken3
0
130
戦略と実行を繋ぐ活用ファーストのデータ分析基盤
tadaken3
0
60
プロダクト活用度で見えた真実 ホリゾンタルSaaSでの顧客解像度の高め方
tadaken3
0
1.2k
Exploratory:プロダクト活用度の話
tadaken3
0
91
[我が社のデータエンジニアリング現場]我が社が考える最強のデータ基盤・開発体制!
tadaken3
0
150
はじめてのWatchOSアプリ。はじめてのiOSアプリ
tadaken3
0
88
拡張現実を活用して幸福度をあげる方法
tadaken3
0
1.9k
チームづくりにおける成功法則 - LINEにおけるHR Techの取り組み- / people analytics tokyo
tadaken3
1
6.3k
Other Decks in Programming
See All in Programming
作って学ぶ、 JSX (TSX) ランタイムの基本
syumai
7
1.6k
OSもどきOS
arkw
0
480
Old Dog, New Tricks: The Java 25 Reinvention - JNation
bazlur_rahman
0
150
「エンジニアインターン、どうやって取った?」準備のリアルを語るLT会 Progate BAR
akiomatic
0
130
Skillsは効率化、Agentsは"自分の拡張"——Builder時代のエージェント編成(CC Night 2026)
wemra
1
120
生成AI時代にこそ効くGo | Why Go Works in the Age of Generative AI
mom0tomo
8
3.2k
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
160
LLM Plugin for Node-REDの利用方法と開発について
404background
0
170
Java × distroless で 軽量なコンテナイメージを / Java on Distroless
contour_gara
0
520
dRuby over BLE
makicamel
2
330
JavaDoc 再入門
nagise
0
320
運用エージェントは "作る" から "育てる" へ - 記憶と自己進化の3層設計パターン / self-evolving-agents-three-layer-agent-design
gawa
12
3.6k
Featured
See All Featured
Sam Torres - BigQuery for SEOs
techseoconnect
PRO
0
280
Heart Work Chapter 1 - Part 1
lfama
PRO
7
36k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
47
8.2k
From π to Pie charts
rasagy
0
200
VelocityConf: Rendering Performance Case Studies
addyosmani
333
25k
A Guide to Academic Writing Using Generative AI - A Workshop
ks91
PRO
1
320
Paper Plane
katiecoart
PRO
1
51k
The agentic SEO stack - context over prompts
schlessera
0
800
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
162
16k
コードの90%をAIが書く世界で何が待っているのか / What awaits us in a world where 90% of the code is written by AI
rkaga
62
44k
Reality Check: Gamification 10 Years Later
codingconduct
0
2.2k
More Than Pixels: Becoming A User Experience Designer
marktimemedia
3
440
Transcript
Google Apps Scriptで 三日坊主を克服する -エンジニア健康サミット 2019- @tadaken3
自己紹介 • タダケン(@tadaken3) • 京都出身 • ピープルアナリスト (LINE 人事 ←
LINE ゲーム事業部 ← 任天堂) • 趣味:自転車、ポケモンGo 愛車のブロンプトン
筋トレしてますか?
筋トレしたいですよね?
せっかくジム通いを始めたけど、 • 仕事が忙しくて • 今日、雨だから • 飲み会に誘われた • やる気が出ない あるある
Google Apps Scriptで三日坊主を克服する 観測さえできれば干渉できる。 干渉できるなら、制御もできる。
①行動の記録 ④送信指示 ③計算結果の 保存 ②経過日数の 計算 スプレッドシート スマートフォン Google Apps
Scriptで三日坊主を克服する Google Apps Script LINE Notify API
Google Apps Scriptで三日坊主を克服する IFTTTでボタンを作る
Google Apps Scriptで三日坊主を克服する スプレッドシートに記録
Google Apps Scriptで三日坊主を克服する //IFTTTの日付形式から通常の日付に変換 function toDateFromIFTTT(str){ str = String(str); str
= str.replace(/at.*/,"")//正規表現でatより後ろの部分を削除 d = new Date(str); return d; } IFTTTの日付形式(str)をdateに変換
Google Apps Scriptで三日坊主を克服する var ss = SpreadsheetApp.getActiveSpreadsheet(); //スプレッドシートを取得 var sheet
= ss.getSheetByName("log"); //シートを取得 //シートの最終行に経過日を計算する式をセットする function setFormuraLastRow(){ //シートの使用範囲のうち最終行を取得 var maxRow = sheet.getDataRange().getLastRow(); //A列の最終行の値を取得 var str = sheet.getRange(maxRow,1).getValue(); //スプレッドシート用の式 var code = '=TODAY() - TO_DATE(B'+ maxRow+')'; //フォーマットした日付をセット sheet.getRange(maxRow,2).setValue(toDateFromIFTTT(str)); //式をセットする sheet.getRange(maxRow,3).setFormula(code); } 経過日数を計算する
Google Apps Scriptで三日坊主を克服する 経過日数が計算できた
Google Apps Scriptで三日坊主を克服する //LINEに通知を送る関数 function sentToLine(message){ var token = "先程取得したアクセストークン";
var options = { "method" : "post", "payload" : "message=" + message, "headers" : {"Authorization" : "Bearer "+ token} }; UrlFetchApp.fetch("https://notify-api.line.me/api/notify",options); } LINE Notifyにメッセージを送る
Google Apps Scriptで三日坊主を克服する function main(){ setFormuraLastRow() var maxRow = sheet.getDataRange().getLastRow();
var passDate = sheet.getRange(maxRow,3).getValue(); var message =""; //経過日が3日もしくは7日以上だったらLINEに通知を送る if (passDate==3 || passDate>=7){ message = "最終トレーニングから"+ passDate + "日経過しました"; sentToLine(message); } } 組わせて実装する
まとめ • IFTTTを使ってシートに行動を記録 • GASで経過日数を計算と送信判定 • LINE Notifyで通知 Google Apps
Scriptで三日坊主を克服する
他にも Fitbit APIと組わせて摂取カロリーと栄養素を通知 あなただけのパーソナルトレーナーが作れる
それでもジムに行けないあなたに • 健康のために「歩くこと」が非常に大切 • 一日10000歩以上が理想的 (最低でも5000歩以上はほしい) • 歩数を増やすと健康だけでなく 脳の機能もアップするという実験結果も
参考:https://www.ncbi.nlm.nih.gov/pubmed/20890449
お気に入りの健康アイテム
– tadaken3 “ポケモンGoのフレンド募集中”
ご清聴ありがとうございました