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
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
AI 時代のソフトウェア設計の学び方
masuda220
PRO
29
12k
Lemonade + Foundry Toolkit でお手軽アプリ開発
seosoft
1
320
代数的データ型って何が嬉しいの? #frontend_phpcon_do
kajitack
8
3.3k
LLMによるContent Moderationの本番運用の裏側と品質担保への挑戦
suikabar
2
480
PHPで使える日時の表現と、その知り方 #frontend_phpcon_do
o0h
PRO
0
230
TypeScript+Orvalで実現する型安全かつ堅牢でスケーラブルなマルチチャネル通知基盤 / TSKaigi Night talks ~after conference~
d0riven
0
320
The ROI of Quarkus for Spring Boot Applications
hollycummins
0
100
運用エージェントは "作る" から "育てる" へ - 記憶と自己進化の3層設計パターン / self-evolving-agents-three-layer-agent-design
gawa
12
3.6k
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
160
IBM Bobを活用したレガシーアプリの最新化
oniak3ibm
PRO
1
190
New "Type" system on PicoRuby
pocke
1
810
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
250
Featured
See All Featured
Stop Working from a Prison Cell
hatefulcrawdad
274
21k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
150
How To Stay Up To Date on Web Technology
chriscoyier
790
250k
Git: the NoSQL Database
bkeepers
PRO
432
67k
Organizational Design Perspectives: An Ontology of Organizational Design Elements
kimpetersen
PRO
1
720
Claude Code どこまでも/ Claude Code Everywhere
nwiizo
65
56k
How To Speak Unicorn (iThemes Webinar)
marktimemedia
1
480
The Cult of Friendly URLs
andyhume
79
6.9k
Learning to Love Humans: Emotional Interface Design
aarron
275
41k
How to optimise 3,500 product descriptions for ecommerce in one day using ChatGPT
katarinadahlin
PRO
1
3.6k
We Have a Design System, Now What?
morganepeng
55
8.2k
How to Think Like a Performance Engineer
csswizardry
28
2.6k
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のフレンド募集中”
ご清聴ありがとうございました