質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.51%

  • Google Apps Script

    1146questions

    Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。

GASで特定の文字列を含むイベントを削除する方法

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 1,071

webmarketer

score 1

 GASで特定の文字列を含むイベントを削除する方法

GoogleAppsScriptで、特定の文字列をタイトルに含むイベントをGoogleカレンダーから削除したいと考えております。
試しに作ってみたのですが、エラーが発生し困っております。
エラーの解決方法、あるいはそもそもこの目的を達成するための違う方法など、ご提案いただけるととても助かります。

流れとしては下記のように考えて作ってみました。
1.シートを取得
2.カレンダーを取得
3.カレンダーの作業対象期間を定義
4.カレンダーのイベントを取得
5.特定の文字列をタイトルに含むイベントを取得
6.5で取得したイベントを削除

すると、下記のエラーメッセージが発生いたしました。

 発生している問題・エラーメッセージ

条件の後に ) がありません。(行 99、ファイル「getCalender」)

 該当のソースコード

/* タスクリストから追加したカレンダーを削除 ByGAS */
function deleteGASCalendar() {

  var mySheet=SpreadsheetApp.getActiveSheet(); //シートを取得  
  var myCal=CalendarApp.getCalendarById('私のメールアドレス'); //特定のIDのカレンダーを取得

  var date=new Date(); //dateを定義
  var startDate=new Date(); //取得開始日
  var endDate=new Date(date);
  endDate.setMonth(endDate.getMonth()+2); //取得終了日

  var myEvents=myCal.getEvents(startDate,endDate); //カレンダーのイベントを取得

  /* ByGASを含む */
  for each(var evt in myEvents){
    if(myEvents.getTitle() == '.*ByGAS'(
      [
        evt.deleteEvent()//イベント削除
      ]
      ); //行99です!
    );
  }

 試したこと

行99~101について括弧の閉じ方が間違っているのかと考えていろいろ試しましたが、うまくいきませんでした。

 補足情報(FW/ツールのバージョンなど)

上記のとおり、このエラーを解決する方法だけでなく、そもそも違う方法をご提案いただくことも、とても嬉しいです。
プログラミング経験0で、GASの勉強を始めてまだ1日なので、とんでもない初歩的な質問かもしれませんが、、、
お手数おかけいたしますが、解決方法がわかる方、なにとぞご教示いただければと思います。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

ツッコミどころはいくつかありますね。。。
とはいえ、プログラミング経験0で勉強初日なら結構頑張られたと思いますよ。

  1. シートの読み込みについて
    カレンダーの処理だけなら、シートを読み込む必要はございません。
    スタンドアロンスクリプトとして作成し、トリガーによる定期処理でいいと思いますが、
    これら、ご自身で調べるには敷居が高いと感じられるなら、現状でも問題ないでしょう。

  2. /*ByGASを含む*/以降について
    Javascriptのfor文もしくはwhile文などのループ構造、if文について確認されたほうがよろしいかと思います。
    (for each in は廃止となっています。)

その上で、webmarketerさんの意図を汲み取り、原文を維持した修正サンプルです。
なお、動作確認はしていませんので参考程度に。

/* ByGASを含む */
   var reg = /.*ByGAS/;//正規表現
   for(var evt in myEvents){
   //もしくは for(var evt = 0, l = myEvents.length; evt < l; evt++){
      if(reg.test(myEvents[evt].getTitle())){//マッチするかどうか
         myEvents[evt].deleteEvent();//イベント削除
      }
   }

[参考]

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2018/02/08 10:46

    ご回答ありがとうございます!いただいたサンプルでやりたいことが実行できました。大変助かりました。ありがとうございました!

    キャンセル

同じタグがついた質問を見る

  • Google Apps Script

    1146questions

    Google Apps ScriptはGoogleの製品と第三者のサービスでタスクを自動化するためのJavaScriptのクラウドのスクリプト言語です。