🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Google Apps Script

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

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

Q&A

1回答

911閲覧

[GAS]Googleカレンダーのスケジュールを指定セルから"1行おき"に出力したい。

hbc

総合スコア16

Google スプレッドシート

Google スプレッドシートは、フリーで利用できる表計算ソフト。Webアプリのためインターネットに接続することで利用できます。チャートやグラフの作成のほか、シートを他のユーザーと共有したり、同時に作業を進めることも可能です。

Google カレンダー

Google カレンダーは、Google社が提供する無料のスケジュール管理ツールです。パソコンやスマートフォン、タブレットなどからアクセスし、スケジュールの追加・変更が可能。Googleアカウントがあれば誰でも使用できます。

Google API

Googleは多種多様なAPIを提供していて、その多くはウェブ開発者向けのAPIです。それらのAPIは消費者に人気なGoogleのサービス(Google Maps, Google Earth, AdSense, Adwords, Google Apps,YouTube等)に基づいています。

Google Apps Script

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

Google

Googleは、アメリカ合衆国に位置する、インターネット関連のサービスや製品を提供している企業です。検索エンジンからアプリケーションの提供まで、多岐にわたるサービスを提供しています。

0グッド

1クリップ

投稿2019/09/29 16:08

編集2020/04/09 11:02

前提

GAS(GoogleAppsScript)に関する質問です。
単純に指定日スケジュールをシートへ落とし込むところまでは実現している。
シート2に日報テンプレートを作成し参照して運用している。
イメージ説明

実現したいこと

用意したテンプレートへ直接落とし込みたい。
添付画像のようなテンプレートの為、取得データを1行おきに出力実行したい。

1.指定セルに日付を入力するだけで実行したい(下記1枚目画像赤枠)
→追記:vardateからgetRange(指定セル).getValueで解決。

2.抽出前に抽出先セル内データをクリアしたい(下記1枚目画像黒枠)
→追記:clearContentでいけそう?

3.指定セルにデータを抽出したい。(下記2枚目画像が完成理想)
→追記※テンプレートが1行おきの為どのような出力命令をすれば良いか困っている。
i=i+2??
appendRowは使えない?

イメージ説明
イメージ説明

発生している問題

1.現在の状態だと、データを抽出するためにわざわざスクリプトエディタを開き、日付を修正してプログラムを起動する。
2.その日のデータだけがほしいので、シートに前日のデータが入っていたら手動で削除する。
3.データが羅列されるだけなので、テンプレートの中の指定セルに入れ込んでいきたい。

該当のソースコード

/* 指定月のカレンダーからイベントを取得する */ function getCalendar() { var mySheet=SpreadsheetApp.getActiveSheet();//.getSheetByName('gcal'); //シートを取得 var no=1; //mySheet.getDataRange().getLastRow(); //シートの使用範囲のうち最終行を取得 var myCal=CalendarApp.getCalendarById('xxx@xxx.jp'); //特定のIDのカレンダーを取得 var date='2019/09/20 00:00:00'; //対象日を指定 var startDate=new Date(date); //取得開始日 var endDate=new Date(date); endDate.setDate(endDate.getDate()+1); //取得終了日 var myEvents=myCal.getEvents(startDate,endDate); //カレンダーのイベントを取得 //mySheet.getRange(1, 1, 10, 10).clearContent(); /* イベントの数だけ繰り返してシートに記録 */ for each(var evt in myEvents){ Logger.log(evt.getLocation()); Logger.log(evt.getDescription()); mySheet.appendRow( [ no, //No evt.getTitle(), //イベントタイトル evt.getStartTime(), //イベントの開始時刻 evt.getEndTime(), //イベントの終了時刻 evt.getLocation(), //場所 evt.getDescription(), //説明 "=INDIRECT(\"RC[-3]\",FALSE)-INDIRECT(\"RC[-4]\",FALSE)" //所要時間を計算 ] ); no++; } }

スクリプトについてはネットからの見様見真似です。
かなりネットで調べたつもりですが、X行おきに出力する方法がわかりませんでした。
10のイベントがあったら10すべて取得し、出力する際X行おきにすべて出力できれば実現できそうです。
どなたかご教示いただけると幸いです。
どうぞ宜しくお願いいたします。

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

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

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

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

可能です。
編集時トリガーをしかけて、シートをクリアして、赤枠セルをvar dateに代入して、出力するときに一行ずつ間隔を空けるだけです。
現在の実装で↑を適用するとき、適切に編集セルを判定しないとどのセルを触ってもリロードされますが、許容範囲でしょう。

投稿2019/10/01 00:27

papinianus

総合スコア12705

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

hbc

2019/10/01 13:57

お世話になります。ご回答ありがとうございます。 可能ということで何よりです。 当方、プログラミング知識が乏しく、上記のソースコードに対しどのようにコーディングを施せば良いのでしょうか。 どの行にどのような命令をすれば良いのかわかっていない状況です。 せっかく教えていただいたのに申し訳ございません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問