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

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

新規登録して質問してみよう
ただいま回答率
85.35%
Google スプレッドシート

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

Google カレンダー

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

Google Apps Script

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

Q&A

解決済

2回答

3045閲覧

それぞれ異なるセルに入力された日付と時間を連結してカレンダーに反映させたい。

memko

総合スコア2

Google スプレッドシート

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

Google カレンダー

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

Google Apps Script

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

0グッド

0クリップ

投稿2021/05/19 10:12

いつも大変参考にさせていただいております。
全く知識がないものの、外注コストがなく、なんとかインターネットで探したスクリプトを参考に、
googleスプレッドシート、gas、googleカレンダーを利用した貸出予約システムを作っています。

イメージ説明
画像のスプレッドシートは他のスプレッドシートから転記されたもので、
管理者の手間を考えると、転記される度に日付のあるセルに直接時間を打ち込むことは考えておりません。

挿入したコードは、画像のスプレッドシートのスクリプトです。
いずれの実行関数もトリガーは変更時に設定しております。

function set_last_updateは、貸出時間と返却時間は毎回同じなので、自動で入力されるようにしています。

◆実現したいこと
貸出日(8列目H)と貸出時刻(17列目Q)、
返却日(9列目I)と返却時刻(18列目R)
を組み合わせてカレンダーに反映させたいのですが、どういったコードで可能なのかわかりません。
今の書き方は一度試してみてできないことを確認しました。

また、おそらくfunction set_last_updateがなくても毎回時刻は同じなので
貸し出し日と開始時刻09:30と返却日と返却時刻18:30をコードでセットしてカレンダーに連携することもできそうな気もするのですが、どのようなコードで可能なのかわかりません。

わかりにくくてすみません。
説明につきまして不足がございましたらご指摘いただければ大変助かります。
以上の件、どなたかご教示いただけませんでしょうか?
何卒よろしくお願い申し上げます。

function set_last_update() { var sh=SpreadsheetApp.getActiveSpreadsheet().getActiveSheet(); var activerange=sh.getActiveRange(); var activerow=activerange.getRow(); sh.getRange(activerow, 17).setValue(new Date(0,0,0,09,30,0)); sh.getRange(activerow, 18).setValue(new Date(0,0,0,18,00,0)); } function createEventFromSheet2() { var sheet, i, myevent, mystart, myend, mydescription, added; sheet = SpreadsheetApp.getActiveSheet(); for(i = 2; i <= sheet.getLastRow(); i++) { myevent = sheet.getRange(i, 1) .getValue(); mystart = sheet.getRange((i, 8),(i,17)) .getValue(); myend = sheet.getRange((i, 9),(i,18)) .getValue(); mydescription = sheet.getRange(i, 7) .getValue(); added = sheet.getRange(i, 15).getValue(); if(added == "") { thisevent = CalendarApp.getDefaultCalendar() .createEvent(myevent, mystart, myend, {description:mydescription}); sheet.getRange(i, 15).setValue("resisterd"); } } }

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

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

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

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

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

guest

回答2

0

要はシートの日付のセルと時刻のセルから日時を合成して、それをカレンダーに登録したいんですよね?
ちょっとコードを書いてみたので参考にしてください。
日付と時刻を合体してあたらしい日時を作るのを、貸出日時と返却日時について行えばいいのかなと思います。

GAS

1 var sheet = SpreadsheetApp.getActiveSheet(); 2 var d = sheet.getRange(1,1).getValue(); // 日付 3 var t = sheet.getRange(1,2).getValue(); // 時刻 4 var datetime = new Date(d.getFullYear(), d.getMonth(), d.getDate(), t.getHours(), t.getMinutes(), t.getSeconds()); // 日付と時刻からあたらしい日時を作る 5 6 var calendar = CalendarApp.getDefaultCalendar(); 7 calendar.createEvent("title", datetime, datetime);

投稿2021/05/22 03:32

itagagaki

総合スコア8402

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

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

memko

2021/05/26 07:47

色々な方法があるのですね、今回は毎回時間が決まっているためもうひと方のご回答をヒントに作成しましたが、itagagaki様のご回答も今後のために活用させていただきたいと思います。この度はありがとうございました。
guest

0

ベストアンサー

gas(というよりもjs) は、日付関連の処理が物凄く面倒なので、ライブラリをおすすめします。

dayjs

取得した日付をcheckoutDateとreturnDateに入れてやれば、それぞれの貸出日と返却日が日付形式で取得できます。

カレンダー関連はこれ
https://tonari-it.com/gas-default-calendar-create-event/

こんな感じでどうでしょう?

gas

1 2 //シートからデータを取得するところは省きます。 3 4 5 //貸し出し日 6 var checkoutDate = "***" //取得した貸出日(H列)データ 7 checkoutDate = dayjs.dayjs(checkoutDate).hour(9).minute(30).$d 8 9 //返却日 10 var returnDate ="***" //取得した返却日(I列)データ 11 returnDate = dayjs.dayjs(returnDate).hour(18).minute(00).$d 12 13 //カレンダーに記入 14 var calendar = CalendarApp.getDefaultCalendar(); 15 var title = '***'; //表示させたいイベント名を入れる 16 calendar.createEvent(title, checkoutDate, returnDate);

投稿2021/05/20 10:05

Tatsunosuke

総合スコア599

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

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

memko

2021/05/26 07:45

以下の形できちんと実行させることができました。 大変参考になりました。ありがとうございました! const sd = sheet.getRange(i, 8).getValue(); const checkoutDate = dayjs.dayjs(sd).hour(9).minute(30).$d const ed = sheet.getRange(i, 9).getValue(); const returnDate = dayjs.dayjs(ed).hour(18).minute(00).$d
Tatsunosuke

2021/05/26 10:50

お役に立てたようで良かったです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問