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

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

新規登録して質問してみよう
ただいま回答率
85.49%
Google Apps Script

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

Q&A

3回答

15351閲覧

GASでyyyy/mm/ddと本日の日付の差を求めるには

yuki_murakami

総合スコア12

Google Apps Script

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

0グッド

0クリップ

投稿2019/06/25 12:02

前提・実現したいこと

Google Apps Scriptで「すでにセルに記載されている未来の日付('yyyy/mm/dd')」と「今日の日付」の差を出し、それが5日未満であった場合にSlackに自動でメッセージを送りたいです。

発生している問題

「すでにセルに記載されている未来の日付('yyyy/mm/dd')」と「今日の日付」の差を出し、

これができなくて困っています。Slackの通知機能とif文を使うことはできるのですが、todayと既存のyyyy/mm/ddの引き算はどのようにしてやるのでしょうか?

ソースコード

一旦、日付の差を求め、それをセルに表示するという構文を作成してみました。

function myFunction() { var sheet = SpreadsheetApp.openById('SpreadsheetのURL'); var today = new Date(); sheet.getSheetByName('slack投稿用').getRange(5,1).setValue(sheet.getSheetByName('slack投稿用').getRange(6,1).getValue() - today); }

試したこと

ggってみましたが有益な情報がまだ得られておらず、何も試せていない状態です。

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

特にありません。GASは一昨日からの初心者です。

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

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

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

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

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

guest

回答3

0

javascript

1 2function q196999() { 3 const sheet = SpreadsheetApp.getActiveSheet() 4 const Val = sheet.getRange("A1").getValue() 5 const target = new Date(Val.getFullYear(), Val.getMonth(), Val.getDate()) 6 const now = new Date() 7 const today = new Date(now.getFullYear(),now.getMonth(),now.getDate()) 8 return Math.floor((target - now)/(60*60*24*1000)) + 1 9 10}

投稿2019/06/25 15:21

編集2019/06/30 16:16
papinianus

総合スコア12705

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

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

0

日付の計算にはMomentの利用をお勧めしています。

javascript

1function dateDiff() { 2 var sheet = SpreadsheetApp.openById('SpreadsheetのURL'); 3 var dateFrom = Moment.moment(); // 今日 4 var dateTo = Moment.moment(sheet.getSheetByName('シート7').getRange(6,1).getValue()); // 未来日 5 Logger.log(dateFrom.diff(dateTo, 'days', false)); // 差 6}

投稿2019/06/26 00:07

編集2019/06/26 00:08
macaron_xxx

総合スコア3191

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

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

0

スプレッドシート上で now()DATEDIF を使って、「すでにセルに記載されている未来の日付('yyyy/mm/dd')」と「今日の日付」の差作り、計算結果の値を参照して5日未満を判定してはいかかがでしょうか?

投稿2019/06/25 14:44

Kazuyuki-T0806

総合スコア326

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.49%

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

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

質問する

関連した質問