紺碧の空3

北海道をノマド的に生きる日々の覚書き

WEB全般 技術覚書

googleスプレッドシートの内容をgoogleカレンダーに読み込む

投稿日:2018年6月24日 更新日:

前から懸案だった、googleスプレッドシートに入力済みの表形式データをgoogleカレンダーに自動で読み込ませるスクリプトを作った。

この表は観測記録なので、日付データとそれに紐づく観測場所や内容がある。直接カレンダーに入力してもいいのだけど、スプレッドシート側では観測者や写真の在処などを細かい別項目で整理したいし、全部を公開しても見づらいだけなので、必要な情報だけ連携させたいと思っていたのだ。

これらはgoogle Apps Scriptという「サーバーサイドスクリプト環境」で提供されている。

Google Apps Scriptってなに?

つまりgoogle driveの中に入ってるスプレッドシートなどgoogle Apps(サーバ内で動くWEBアプリケーション)を動かすためのスクリプトで、MS officeでいうVBAみたいなことができる。javascript互換なんだって。

昔いじったことのあるgoogleAPIなどと同じgoogleデベロッパーズの中にリファレンスが。

カレンダー関連トップ https://developers.google.com/apps-script/advanced/calendar

日本語にしてくれている人http://googlestyle.client.jp/calendar_services/class_calendar.html

参考にしたコードはリファレンスにも載ってるこんなかんじ。
GoogleスプレッドシートからGoogleカレンダーにインポート

ただ、これだとgetDefaultCalendar()でデフォルトのカレンダーにしか連携されず、

どうしたらいいかちょっと悩んで、getCalendarById(‘カレンダーID’)にした。

あと、本当は日付が空白だったら読み飛ばしさせたかったんだけど、javascriptの日付判定でハマって
(javascript自体は日付チェック関数とか持ってないんだった・・・いつもその辺でイラッとしてしまうが、javascriptに慣れてないせいで期待しすぎてる自分が悪いんだろう)

一旦諦めてスプレッドシート側で正しい日付形式を渡すよう編集した。

後になって思いついたのだが、よく考えたらGAS自体がjavascriptのラッパー環境だとすれば独自関数もあるよね?と思って探したら、Utilitiesクラスでできそう。・・・どうも勘が鈍っている。

参考:Google Apps Scriptでプログラミングを学ぶ 第5回

function createEventFromSheet() {
    var sheet, i, myevent, mystart, myend, mylocation, mydescription, mystartrow, myendrow;
    var sheet = SpreadsheetApp.getActiveSheet();

//カレンダーIDは◯◯@group.calendar.google.comのような形式
    var cals = CalendarApp.getCalendarById('カレンダーID');

//シートの固定セルに読み込み開始・終了行を入力
    mystartrow = sheet.getRange(5, 14).getValue();
    myendrow = sheet.getRange(5, 15).getValue();  

//列番号はワークシートに合わせて固定値で変更
    for(var i = mystartrow; i <= myendrow; i++) {
        myevent = sheet.getRange(i, 8).getValue();
        mystart = new Date(sheet.getRange(i, 14).getValue());
        myend = new Date(sheet.getRange(i, 15).getValue());
        mylocation = sheet.getRange(i, 6).getValue();
        mydescription = sheet.getRange(i, 16).getValue();
        var event = cals.createEvent(myevent, mystart, myend,{location:mylocation, description:mydescription});
		}
}

おそらくこれくらいなら、ツイッターのログとgoogleカレンダーの連携で使っているZapierでも実現できるんだけど、こっちですぐ出来そうなのでやってみました。

結果、wixのgoogleカレンダーウィジェット(アプリ)で表示させてるのがこれ。

蜃気楼・幻氷の観測記録

今のところ今年の5月くらいまでデータ入ってます。(4月あたりを見るとわかりやすい)

→修正

今はこちらで公開しています

 

追記:アイキャッチ画像に、developerのアイコンを使ってみたんだけど、どうも googleさんは各種アイコンの利用に厳しいようなので(各サービスごとに方針が出ており、出てないものは使わないほうがよさそう)、許可が出てるgoogle driveのアイコンに変えました。ドライブのバッジとブランドの使用

初版公開日時: 2014年8月17日

こちらの記事もおすすめ

 

 

-WEB全般, 技術覚書

執筆者:


comment

メールアドレスが公開されることはありません。 が付いている欄は必須項目です

CAPTCHA


関連記事

覚書き

google my map埋め込み時に拡大率、中心を変更する、ルートの色を変える

今日はPCセットアップとは違う備忘メモ。 google map がらみって、仕様変更めちゃくちゃ激しいですよね。 googleさんが、一番重要視しているっていう意図が何となく伝わってきます。 (世界を …

スマホとキャリア変更について【レビュー未満】

ひさびさです、こちらのブログ。 ってか、メインのブログも全然書けてません…。。 なんだろ、やっぱり時間ないよねー。何かの消費に費やされてるんだろうねぇ。。。 今日はちょっと気分転換に・・・ (全然宿題 …

F-03J docomo キッズケータイ

「F-03J キッズケータイ」レビュー☆大人でも通話専用機として使える!

年末です。ついに。 このままでは、年を越してしまいます! 絶対書きたい、と今年思っていたネタがいくつかあって・・・ これを書かずに年は越せない!と思いつめているので、今更ですが書きますね。 まずは、昨 …

覚書き

【やよいの青色申告】医療費控除と高額医療費の関係(確定申告)

今年も確定申告の季節です。 昨年、インフルで倒れていたのに、そのあとの頑張りで何とかなってしまったので・・・ どうもエンジンがかからないという悪循環に入っております。。。 (言い訳の天才) それで、と …

googleフォーム医療費控除

確定申告で医療費控除、アプリ?Excel?既製マクロもテンプレートもイマイチ。そうだ、google フォームがあるじゃないか。瞬殺入力→集計。

今年の確定申告準備。正直、これまでのキャリアの中で、一番取り組み始めるのが遅れました・・・ 気持ちに余裕があるときは1月から。たいてい2月中旬には始めてたんだけど。今年はちょうど旅行があって・・・帰っ …











スポンサーリンク