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
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
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
エージェンティックRAGにAWSで入門しよう!
har1101
8
1.4k
Vite+ Unified Toolchain for the Web
naokihaba
0
230
New "Type" system on PicoRuby
pocke
1
790
AIチームを指揮するOSS「TAKT」活用術 / How to Use “TAKT,” an OSS Tool for Orchestrating AI Teams
nrslib
6
870
A2UI という光を覗いてみる
satohjohn
1
120
Dataformのリポジトリを立ち上げるときにまずやること / dataform-day0-2026
snhryt
0
140
DynamoDBには集計系のクエリがないけどなんとかしたい
musan
1
130
Datadog × OpenTelemetry 入門と実践のあいだ
kn_to_maxpno
1
150
ローカルLLMを使ってB2Bサービスを作っていての学び
yaotti
0
160
軽量Java基盤の設計 DIコンテナに頼らない、長期保守と1秒起動の実現 JJUG CCC 2026 Spring
macha64
0
490
フロントエンドとバックエンドで「1文字」を揃えよう
youkidearitai
PRO
0
250
決定論的オーケストレーションの設計と実装 / Design and Implementation of Deterministic Orchestration
nrslib
3
1.3k
Featured
See All Featured
The Spectacular Lies of Maps
axbom
PRO
1
800
How Software Deployment tools have changed in the past 20 years
geshan
0
34k
Save Time (by Creating Custom Rails Generators)
garrettdimon
PRO
32
3.4k
技術選定の審美眼(2025年版) / Understanding the Spiral of Technologies 2025 edition
twada
PRO
118
120k
The AI Revolution Will Not Be Monopolized: How open-source beats economies of scale, even for LLMs
inesmontani
PRO
3
3.5k
Paper Plane
katiecoart
PRO
1
51k
The Straight Up "How To Draw Better" Workshop
denniskardys
239
140k
[RailsConf 2023] Rails as a piece of cake
palkan
59
6.7k
Imperfection Machines: The Place of Print at Facebook
scottboms
270
14k
SEO Brein meetup: CTRL+C is not how to scale international SEO
lindahogenes
1
2.7k
Designing Dashboards & Data Visualisations in Web Apps
destraynor
231
55k
Taking LLMs out of the black box: A practical guide to human-in-the-loop distillation
inesmontani
PRO
3
2.3k
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のフレンド募集中”
ご清聴ありがとうございました