GASを使用してGoogle CalendarのLocationに文字列を記録したイベントを削除する

はじめに

MMORPGドラゴンクエスト10のエンドコンテンツ、常闇の聖戦をかなり頑張ってやっていた時期がありました。日によって常闇ボスの強さのレベルが変わっており、それを10年分Google Calendarに登録していたのですが、常闇は殆どやらなくなり、カレンダーで目にするのが煩わしくなっておりました。

カレンダー自体を消して作り直しても良かったのですが、常闇以外の予定は備忘録として残したかったので、GASを使用して特定のイベントをカレンダーから削除するスクリプトを作りました。参考にしたのは下記のURLの記事です。

teratail.com

kido0617.github.io

www.xenos.jp

macprimary.white-doll.net

注意点

GASは無償ライセンスですと、使用するにあたって制限事項があります。仕様書を読み込んでいないのでうろ覚えですが、1実行は6分以内、多くのカレンダーイベントの削除?ができないなどです。

10年分のイベントなので約3650件で、スクリプト1回では処理しきれません。1実行を6分以内に収める時間判定、遅延処理、トリガー、プロパティサービスという仕組みを使用しました。

トリガーというのはWindowsで言うところのタスクスケジューラみたいなものです。手動実行して5分後にトリガーを登録し、トリガーは更に1分後に関数を再帰呼出ししております。

プロパティサービスはグローバル変数というか、ローカルストレージみたいなものです。日付の範囲のどこまでを削除実行したのかは永続的に参照する必要があったので使用しています。

日付の範囲を作成→時間判定→トリガー処理→文字列検索・カレンダーのイベント削除→遅延処理というステップで処理します。

コード

function myFunction() {
  //開始時間
  var startTime = new Date();
  //カレンダーIdから取得
  var cal = CalendarApp.getCalendarById("ここにはカレンダーIdを入れます");
  //途中経過保存用
  var properties = PropertiesService.getScriptProperties();
  //何日目まで処理したかを保存するときに使用するkey
  var startDateKey = "startDate";
  //トリガーIDを保存するときに使用するkey
  var triggerKey = "trigger";
  //開始日を取得
  var startDate = properties.getProperty(startDateKey);
  if (!startDate) {
  //初めて実行する場合は指定日付で初期化
    startDate = new Date("ここには開始日付を入れます");
  } else startDate = new Date(startDate);
  //終了日を入力
  var endDate = new Date("ここには終了日付を入れます");
  var events = cal.getEvents(startDate, endDate);
  for (var n = 0; n < events.length; n++) {
    var diff = parseInt((new Date() - startTime) / (1000 * 60));
      //5分経過していたら処理を中断
    if (diff >= 5) {
      //処理日を保存
      var dateStr = Utilities.formatDate(events[n].getStartTime(), "JST", "yyyy/MM/dd");
      properties.setProperty(startDateKey, dateStr);
      //トリガーを発行
      setTrigger(triggerKey, "myFunction");
      return;
    }
    if (events[n].getLocation().match(/ここには検索文字列を入れます/)) {
      //イベント削除
      events[n].deleteEvent();
    }
    //1秒遅延
    Utilities.sleep(1000);
  }
  //全て実行終えたらトリガーと何日目まで実行したかを削除する
  deleteTrigger(triggerKey);
  properties.deleteProperty(startDateKey);
}
//指定したkeyに保存されているトリガーIDを使って、トリガーを削除する
function deleteTrigger(triggerKey) {
  var triggerId = PropertiesService.getScriptProperties().getProperty(triggerKey);
  
  if(!triggerId) return;
  
  ScriptApp.getProjectTriggers().filter(function(trigger){
    return trigger.getUniqueId() == triggerId;
  })
  .forEach(function(trigger) {
    ScriptApp.deleteTrigger(trigger);
  });
  PropertiesService.getScriptProperties().deleteProperty(triggerKey);
}
 
//トリガーを発行
function setTrigger(triggerKey, funcName){
  //保存しているトリガーがあったら削除
  deleteTrigger(triggerKey);
  var dt = new Date();
  //1分後に再実行
  dt.setMinutes(dt.getMinutes() + 1);
  var triggerId = ScriptApp.newTrigger(funcName).timeBased().at(dt).create().getUniqueId();
  //あとでトリガーを削除するためにトリガーIDを保存しておく
  PropertiesService.getScriptProperties().setProperty(triggerKey, triggerId);
}

解決できなかったこと

何故かトリガーが途中で記録されずに終了してしまうことがありました。何度かスクリプトを手動で実行して全てのイベントを削除できました。

2019/08/11
全体的に変数の命名やインデント、セミコロンの入れ忘れ、ループ処理の負荷を見直し、コードを書き換えました。

免責事項

本ページに掲載されているスクリプトの使用、または使用不具合等により生じたいかなる損害に関しましてブログ管理人は一切責任を負いません。

2019福島牝馬ステークスの予想

福島芝1800mの過去10年の分析

  1. 戸崎騎手が勝率23%で、優秀。
    ランドネ
  2. 松岡騎手は複勝率45%で、優秀。
    ウインファビラス
  3. ディープインパクト産駒は連対率30%で、このコースでは安定している。
    ワキタエンカ、マジックストーム、ダノングレース

福島牝馬ステークスの過去10年の分析

  1. 角居厩舎驚異の連対率100%。
    ランドネ
  2. 3着までの平均上がり3Fは35秒3。切れ味は重要視されず前目で競馬ができることが重要。
  3. 前走コースは中山芝1800で連対率驚異の77.8%。
    ワキタエンカ、ランドネ、デンコウアンジュ、ウインファビュラス、フローレスマジック

第5回横浜鶴見川ハーフマラソンを振り返る。

はじめに

 4/14にスポーツワン主催の第5回横浜鶴見川ラソンハーフマラソンを走ってきました。ここにエントリーした理由は主に3つあります。

1)Runnetでの検索

2)職場の後輩から鶴見川の河川敷コースが走りやすいと聞いていたので興味あった

3)前回(三浦国際市民マラソン)のリベンジでハーフでサブ2を目指す

GarminGPSウォッチで走行ログを取ったので、データを見ながら振り返りたいと思います。

 

コース

f:id:taco0603_old:20190417030809j:plain

横浜鶴見川河川敷

 鶴見川を南から北に向かって往復5kmのコースを4周しました。河川敷なので平坦なコースですが、1km過ぎたあたりに高架下があり、そこは下り坂。当然復路は上りになり、10m程度の距離ですがきつく感じました。当日は北風が吹いており、帰りは向かい風になります。4m程度の軽風で気温は16℃、降雨もなかったのでハーフを走るには良いコンディションだったと思います。ハーフマラソンの部門は50人程度だったでしょうか、小規模で混雑等なく、走りやすかったのではないかと。

スタッフの方はアルバイトの高校生の方が多かったと思いますが、沿道で応援してくれたので励みになりました。主催の株式会社スポーツワンの皆様、楽しいイベントをありがとうございました。

トイレ・更衣室

トイレは河川敷にある公衆トイレのみでした。男女別のテントが用意してあって、そこで着替えができました。

結果

距離(km) 区間タイム 到達時間
1 5:17 0:05:17
2 5:11 0:10:28
3 5:14 0:15:42
4 5:23 0:21:05
5 5:33 0:26:38
6 5:25 0:32:04
7 5:19 0:37:22
8 5:18 0:42:41
9 5:37 0:48:17
10 5:28 0:53:45
11 5:37 0:59:22
12 5:21 1:04:44
13 5:24 1:10:07
14 5:18 1:15:25
15 5:27 1:20:53
16 5:33 1:26:26
17 5:29 1:31:55
18 5:31 1:37:26
19 5:32 1:42:58
20 5:51 1:48:48
20.92 5:20 1:53:42

 

5分30秒前後のペースを守ってサブ2を達成できました。到達順位は35位でした、早い人は4分/kmペースを維持できるので、僕から見ると超人に見えますね。

 

良かったところ

1)マシンや自重の筋力トレーニン

レッグプレス、レッグレイズやニーリフト、ニータックの効果なのか、おしりや脹脛に痛みや疲労がおきることはなかったです。

2)朝食
アミノバイタルプロテイン含めて1500kcalとったので最後までスタミナ切れは起こさなかったです。

3)スリップストリーム

先行するランナーの後ろについていたので、地味に風よけとペースメーカーとして役に立ちました。

4)給水

4km地点でスポーツドリンクを飲みましたので脱水にもならなかったです。

5)サブ2

目標を達成できて嬉しかったです。

6)コンタクトレンズ
メガネが曇るときになってしまうので。

 

悪かったところ

1)ゴール後に右肩と右膝に激痛

自己流で走っているので、右に傾いていてランニングフォームが悪いのかもしれません。

2)荷物が多かった

ランウェアに近い状態で行ったほうが身軽で楽だったかもしれません。

マタイ受難曲/バッハ・コレギウム・ジャパン@彩の国さいたま芸術劇場 音楽ホール

はじめに

自分にとって、今年初のバッハ・コレギウム・ジャパンの公演を彩の国さいたま芸術劇場で聞いてきました。受難週にあたる今日の曲目はマタイ受難曲です。

全曲通して3時間近くもあるバッハの大作を聞くのは、僕にとっても音楽を通した精神の修行のような意味があります。昔、鈴木雅明音楽監督が受難曲とは聖書の記事を通して、個人の信仰・信条と向き合う音楽、なんて仰っていたように思います。素晴らしい曲であるものの、通して聞くのは感動とともに結構しんどく、演じるオケの皆さんには感謝しかありません。

例年であればBCJの主戦場であるオペラシティコンサートホールに行くんですが、今回は彩の国さいたま芸術劇場にしました。

結論から言えば、オペラシティコンサートホールよりも小規模のホールの1階席だったので、今までにない発見があり良かったと思いました。また、今回のオケはチェロが鈴木秀美コンマス寺神戸亮BCJオールスターと言う布陣だったのもラッキーでしたね。公演の前にマタイの新録音をしたそうなので、良い記念にもなり、アルバムも楽しみです。

席は9割ぐらいは埋まっていたように思います。埼玉まで聞きに来るなんて、筋金入りの古楽マニア、BCJマニアでしょうね。コンサートプログラムも鈴木御大の和訳がのっており、良いプレゼントを頂いたと思います。僕はドイツ語も聖書の知識も少ないのでマタイを楽しむ良い道標になると思います。

気づいたこと

  1. パイプオルガンにフェンダーミラーみたいなものが2つついていた。
    これは後ろの指揮者を見るためだったのかなぁと思います。
    オペラシティだと2階にパイプオルガンが配置されており、ミラーはなかった気がします。
  2. Erbarme dichではチェロは弓ではなく指だった。
    CDの音源では「ポンポン」何がなってるのかなぁとずっと不思議でした。
  3. Komm, suses Kreuzがヴィオラ・ダ・ガンバのソロと気がついた。
    バスのアリアで好きな曲なんですが、これがガンバの音色なんだなぁと。
  4. 激しい曲はより激しく、沈鬱な曲は弱く微妙に。
    鈴木雅明音楽監督の振りのアクションに応じてオケが緩急つけた演奏になっており、メリハリを感じる素晴らしい演奏でした。

 

 

2019皐月賞の予想

中山芝2000mの過去10年の分析

  1. ルメール騎手が驚異の勝率30%で、軸からは外せない。
    サートゥルナーリア
  2. デムーロ騎手は勝率14%程度。意外と乗れていない
    アドマイヤマーズ
  3. 武豊騎手は連対率17%程度で、平成の天才も近年は不振傾向かも。
    ファンタジスト
  4. ダイワメジャー産駒は勝率7%程度で、このコースを苦手としている。
    アドマイヤマーズ
  5.  ロードカナロア産駒は勝率21%と軸には外せない。
    サートゥルーナーリア、ファンタジスト
  6. ディープインパクト産駒は連対率24%と安定感がある。
    ダノンキングリー、サトノルークス
  7. ケープブランコ産駒はこのコースで着なし。オープン馬1頭なのでしかたないか。
    ランスオブプラーナ

皐月賞の過去10年の分析

  1. 3着までの平均タイムは1分59秒4。持ち時計が遅い馬は軽視して良い。
  2. 3着までの平均上がり3Fは35秒。切れ味よりは中山の急坂をこなせるパワーが必要。
  3. 前走共同通信杯で勝った馬が最多の4勝。
    サトノキングリー
  4. 角居調教師が驚異の複勝率75%。
    サートゥルーナーリア

2019桜花賞の予想

阪神芝1600mの過去10年の分析

  1. コース形態からはルメール騎手が勝率29%、連対率43%と驚異の数字。
    紐からは外せないか。
    グランアレグリア
  2. デムーロ騎手は連対率35%。得意としているコース。
    アクアミラビリス
  3. 北村友一騎手は勝率5.6%。うーん、という数字。
    クロノジェネシス
  4. ディープインパクト産駒は率11.1%。このコースは思った以上に得意ではない。
    ダノンファンタジー、グランアレグリア、シェーングランツ、ノーブルスコア、レッドアステル
  5. ロードカナロア産駒は驚異の勝率20%。
    ルガールカルム
  6. バゴ産駒は連対率47%であり、紐からは外せないか。
    クロノジェネシス
  7. 藤澤厩舎は複勝率65%。狙い通りに取ってきている。
    シェーングランツ、グランアレグリア

 

桜花賞の過去10年の分析

  1. 武豊騎手は連対率11%。平成の桜花賞最多勝利も近年は不振。
    シェーングランツ
  2. 3着以内の平均タイムは1分34秒3。やはりある程度のスピードは要求される。
  3. 3着以内の平均人気は4.0。

2019ニュージーランドトロフィーの予想

中山芝1600mの過去10年の分析

  1. コース形態からはルメール騎手が勝率24%、連対率35%程度で狙い目。
    アガラス
  2. 戸崎騎手は複勝率42%。得意としているコース。
    ヴィッテルスバッハ
  3. ブラックタイド産駒は率4.2%、このコースを苦手としている。
    アガラス、ミッキーブラック
  4. ジャスタウェイ産駒は複勝率40%であり、新種牡馬としては立派な数字。
    カリボール
  5. ノヴェリスト産駒は連対率24%。穴で一考の余地あり。
    コスモカレンドゥラ

 

ニュージーランドトロフィーの過去10年の分析

  1. 1番人気が4勝している
  2. 平均タイムが1分35秒1。
  3. 本番のNHKマイルカップにはほとんど結びつかないレース。
    過去に連勝できたのはカレンブラックヒルしかない。
  4. 勝ち馬の平均人気は4.1。
  5. 栗東所属馬が9勝。
  6. 3着以内の平均馬体重は478.9kg。ガサのない馬や牝馬は評価を下げて良い。