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

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

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

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

Q&A

解決済

1回答

5157閲覧

日本時間の午前8時から次の日の午前8時までのGmailを取得したい

HYoshitaka

総合スコア14

Google Apps Script

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

0グッド

0クリップ

投稿2021/02/17 03:04

日本時間の指定日の午前8時から次の日の午前8時までのGmailを取得したいのですが、下記のコードだと指定日の午前9時から翌日の午前9時以前まで取得してしまいます。
解決策をご教示いただけますでしょうか。

//指定した日付を取得 let dateBefore = new Date(date.getFullYear(),date.getMonth(),date.getDate()+1,date.getHours(),date.getMinutes()); let timeStampBefore = Utilities.formatDate(dateBefore, 'Asia/Tokyo', 'yyyy/MM/dd'); let timeStampAfter = Utilities.formatDate(date, 'Asia/Tokyo', 'yyyy/MM/dd'); Logger.log(timeStampBefore); const config = getConfig(); const SEARCH_BOX = `subject:${config.searchText} before:${timeStampBefore} after:${timeStampAfter}`; // before:取得したい日にちの次の日 after:取得したい日にち /* スプレッドシートのシートを取得と準備 */ const mySheet = SpreadsheetApp.openById(config.spreadSheetId).getSheetByName(config.spreadSheetTabName); //シートを取得 let messages = [['date','Subject', 'From', 'To','Body']]; GmailApp .search(SEARCH_BOX, 0, 500) .forEach(function (thread) { thread.getMessages().forEach(function (message) { let date = message.getDate(); let reformDate = Utilities.formatDate(date, 'Asia/Tokyo', 'yyyy/MM/dd/HH:mm'); let subject = message.getSubject(); let to = message.getTo(); let from = message.getFrom(); let plainBody = message.getPlainBody().slice(0,100); messages.push([reformDate,subject, from, to,plainBody]); }); });

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

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

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

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

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

guest

回答1

0

ベストアンサー

日本時間の指定日の午前8時から次の日の午前8時までのGmailを取得したいのですが、下記のコードだと指定日の午前9時から翌日の午前9時以前まで取得してしまいます。

yyyy/MM/ddで整形しているので、時刻部分の指定がされなくなり、グローバル時刻の該当日付の全メールを取得し、日本時間で表示したことで、午前9時から午前9時までに見える、という解釈をすべきです。

なお、公式のヘルプでは、時刻指定の方法は明示されておらず、裏技として存在するUNIX時間での指定を使うことで、実現できるそうです。
Google Apps ScriptでGmailの情報を取得する際に、受信日時を細かく指定する方法

投稿2021/02/17 04:53

YT0014

総合スコア1750

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問