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
EnebularMeetup_GoogleCalendar
Search
Sponsored
·
Your Podcast. Everywhere. Effortlessly.
Share. Educate. Inspire. Entertain. You do you. We'll handle the rest.
→
NearMugi
June 03, 2022
Technology
310
0
Share
Embed
Copy iframe code
Copy JS code
Copy link
Start on current slide
EnebularMeetup_GoogleCalendar
NearMugi
June 03, 2022
More Decks by NearMugi
See All by NearMugi
nekoIoTLT_NearMugiLLM
nearmugi
0
420
nekoIoTLT_CatAndColorSensor
nearmugi
0
970
VisualProgramming_GoogleHome_LINE
nearmugi
1
630
nekoIoTLT_ToyAndVoiceAnalysis
nearmugi
0
410
nekoIoTLT_Demachi
nearmugi
0
470
nekoIoTLT_SearchBlackObject
nearmugi
1
710
nekoIoTLT_nekoDeeplearning
nearmugi
0
350
nekoIoTLT_nekoGohan
nearmugi
0
570
nekoIoTLT_Tsumetogi
nearmugi
1
750
Other Decks in Technology
See All in Technology
ぼっちではじめた登壇が「51名」「241件」の発信に化けた
subroh0508
0
160
OTel × Datadog で 「AI活用」を計測し、改善に繋げる
shihochan
0
280
マルチアカウント環境での コーディングエージェントを使った障害調査が大変なので AIエージェントにReadOnly権限を付与してみた / ReadOnly AI Agents for Multi-Account AWS Incident Response
yamaguchitk333
2
110
手塩にかけりゃいいってもんじゃない
ming_ayami
0
600
2026 TECHFRESH 畢業分享會 - 開發日常大解密!從領域驅動到企業級上線
line_developers_tw
PRO
0
1.2k
SONiCのLinuxベースを活かしたZabbix監視
sonic
0
220
SONiCで構築・運用する生成AI向けパブリッククラウドネットワーク ~実装編~
sonic
0
270
MUSUBI 田中裕一『AIと共に行う「しごとのリデザイン」- スモールバックオフィス編』AI Ops Lab #4
musubi
0
230
AI時代のコスト管理を考えよう〜明日から使える実践AWSノウハウ~
yoshimi0227
0
220
GitHub Copilot 最新アップデート – 「一歩先」の実践活用術
moulongzhang
4
1.5k
RAG を使わないという選択肢
tatsutaka
1
260
アジャイルな経理と Claude Code と経営の未来
kawaguti
PRO
3
150
Featured
See All Featured
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
AI Search: Where Are We & What Can We Do About It?
aleyda
0
7.6k
The AI Search Optimization Roadmap by Aleyda Solis
aleyda
1
5.9k
brightonSEO & MeasureFest 2025 - Christian Goodrich - Winning strategies for Black Friday CRO & PPC
cargoodrich
3
730
The #1 spot is gone: here's how to win anyway
tamaranovitovic
2
1.1k
How People are Using Generative and Agentic AI to Supercharge Their Products, Projects, Services and Value Streams Today
helenjbeal
1
220
Dealing with People You Can't Stand - Big Design 2015
cassininazir
367
27k
How to Talk to Developers About Accessibility
jct
2
240
The Spectacular Lies of Maps
axbom
PRO
1
810
Claude Code のすすめ
schroneko
67
230k
Rails Girls Zürich Keynote
gr2m
96
14k
GraphQLの誤解/rethinking-graphql
sonatard
75
12k
Transcript
定期的な予定をGoogleカレンダーへ 簡単に追加できる仕組みを作ってみた 2022.06.02 【オンライン】enebular developer meetup
自己紹介 NearMugi(ニアムギ) 普段はねこIoTLTで活動しています。 ねこ2匹飼っています。
イントロ 今回は「定期的な予定をGoogleカレンダーへ 簡単に追加できる仕組みを作ってみた」お話で す
イントロ 我が家では定期的な予定(例えば子どもの迎えの担当)を Googleカレンダーを使って家族で共有しています。
イントロ そこで妻より・・・ ・Googleカレンダーの予定をコピーするのが面倒 ・簡単にコピーできる方法ない?
イントロ 確かに手間がかかります ・コピーしたい予定をクリック ・複製を選択 ・日付を変更 ・保存
イントロ 簡単に複製する機能はなさそうだったため、作ってみました
仕組みの概要 入力を簡単にするため、スプレッドシートにある情報を Googleカレンダーへ自動で反映させるようにしました 一つ一つ予定を入れるよりも楽!
仕組みの概要 ただ、スプレッドシートを開いて編集するのも手間なので AppSheetを使ってLINEから入力できるようにしています。
仕組みの概要 全体像はこんな感じです ① ② ③ ④ ①LINEからSpreadSheetへ ②Cronで定期的に取得 ③カレンダー情報と比較 ④カレンダーを更新
Node-RED の部分 Node-REDのフローは以下の通りです。 1. Googleカレンダーの情報を取得 2. スプレッドシートの情報を取得 3. 差分(追加/更新/削除)を判別 4.
Googleカレンダーへ反映
Node-RED の部分 1. Googleカレンダーの情報を取得 Googleカレンダーへアクセスするノードがありませんでした・・ そのためPython + execノードで処理しています
Node-RED の部分 (補足)Googleカレンダーにアクセスするソースについて 取得(Get)・追加(Insert)・更新(Update)・削除(Delete)を指定する テキストファイルを渡すと、いい感じに処理してくれるプログラムを用意しました 1文字目がG の場合は Googleカレンダーの情報をGetする
Node-RED の部分 追加・更新・削除の場合 同じように1文字目が I の場合は追加 Uの場合は更新 Dの場合は削除 となります。
Node-RED の部分 2. スプレッドシートの情報を取得 スプレッドシートはノードがあるので、簡単にデータを取得できます
Node-RED の部分 3. 差分(追加/更新/削除)を判別 ここが一番の難関でした。 判別のルールは以下の通りです。 スプレッドシート : o ,
Googleカレンダー : x -> 追加 スプレッドシート : o , Googleカレンダー : o(完全一致) -> スキップ スプレッドシート : o , Googleカレンダー : o(一部差分) -> 更新 スプレッドシート : x , Googleカレンダー : o -> 削除
Node-RED の部分 比較できるようにGoogleカレンダーのデータと、スプレッドシートのデータを整形しま す 取得したGoogleカレンダーのデータ こんな感じに整形
Node-RED の部分 どのように整形しているかというと、splitノードで1行ずつ読み、jsonata形式でコネコ ネしてファイルに出力しています
Node-RED の部分 スプレッドシートのデータも同様に整形していきます 取得したスプレッドシートのデータ こんな感じに整形
Node-RED の部分 Googleカレンダーと違い、1行目がヘッダーであること、途中に空白行があることに注 意して整形します。 取得したデータ スプレッドシート
Node-RED の部分 整形の考え方はGoogleカレンダーとやり方は同じです ヘッダーや空白行はスキップします
Node-RED の部分 データの形式は揃ったのであとは比較するだけです。
Node-RED の部分 整形のときと同じようにsplitノードやchangeノードで比較・・・ したかったのですが断念しました・・・ 日付のあり/なしで追加と削除は出来そうかなと思ったのですが 更新を判定するには他の項目(summaryなど)もチェックするので お手上げでした。
Node-RED の部分 そのため、比較用のプログラムを用意して解決しました Pythonでは素直に出来ました
Node-RED の部分 4. Googleカレンダーへ反映 すでに材料と道具が揃っています。比較した結果をプログラムに渡してあげればOKです。
まとめ ・データの読み込み・比較・書き込みといったお勉強のようなシステム 作りでした。 ・Googleカレンダーのノードがあるといいな。。 以上となります。 ご清聴ありがとうございました。