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

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

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

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

Gmail

GmailとはGoogleによって提供されているウェブメールのサービスのことです。

Google Apps Script

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

メール

メールは、コンピュータネットワークを利用し、 情報等を交換する手段のことです。

Google

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

Q&A

解決済

1回答

1746閲覧

Gmail自動転送 スプレッドシート・GAS使用

退会済みユーザー

退会済みユーザー

総合スコア0

Google スプレッドシート

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

Gmail

GmailとはGoogleによって提供されているウェブメールのサービスのことです。

Google Apps Script

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

メール

メールは、コンピュータネットワークを利用し、 情報等を交換する手段のことです。

Google

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

0グッド

0クリップ

投稿2020/06/17 08:23

前提・実現したいこと

検索条件に一致し、かつ最後の送信者が自分ではない時にメールを指定したアドレスへ転送したい。
初心者のため引数のどこでエラーが出ているか分からず困っています。

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

44行の GmailApp.sendEmail(forwardTo, forwardSubject, forwardBody); で無効なメールとエラーが出てしまう。

該当のソースコード

function mailForward() { //検索条件に合致するメールを抽出 var spreadsheet = SpreadsheetApp.getActiveSpreadsheet(); var subject1 = spreadsheet.getRange('AB51') var query = 'subject:subject1 newer_than:1d'; //検索条件 var threads = GmailApp.search(query, 0, 10); //条件に合致するメールのスレッドを取得 var messages = GmailApp.getMessagesForThreads(threads); //スレッド内のメールを取得。[スレッド番号][メッセージ番号]の2次元配列になる var address1 = spreadsheet.getRange('AA51') var myMailAddress = address1; //最後の送信者がこのアドレス(自分)に合致していないものは未返信 var address2 = spreadsheet.getRange('AE51') var forwardTo = address2; //抽出した結果を転送する転送先アドレス var forwardSubject = '<テストメール>'; //抽出した結果を転送する転送メールの件名 var forwardBody =''; //抽出した結果を転送する転送メールの本文 //1スレッドずつ未返信か確認 for(var i=0; i < messages.length; i++) { var lastNum = messages[i].length-1; //スレッドの最後のメールのインデックスを取得(indexは0から始まるから-1する) //Logger.log('やり取り数:'+ lastNum); var lastSender = messages[i][lastNum].getFrom(); //最後のメールの送信者を取得 //Logger.log('最後の送信者:'+ lastSender); //未返信メール判定 if(lastSender.indexOf(address1) == -1){ //indexOfは文字列に指定した文字が含まれていない場合は戻り値が-1となる var Body1 = spreadsheet.getRange('AC51') var messageId = messages[i][lastNum].getId(); //メッセージIdを取得 var messageDate = messages[i][lastNum].getDate(); //メッセージの受信日時を取得 var messageSubject = messages[i][lastNum].getSubject(); //メッセージの件名を取得 var messageBody = messages[i][lastNum].getPlainBody(); //メッセージの本文を取得 forwardBody = forwardBody + '<テストメール>' + Body1 + 'メッセージID : ' + messageId + '\r\n' + '送信者 : ' + lastSender + '\r\n' + '送信日 : ' + messageDate + '\r\n' + '件名 : ' + messageSubject + '\r\n' + '内容 : \r\n' + messageBody + '\r\n' + '+++++++++++++++++++++++++++++++++++++++++++++++\r\n\r\n'; //転送用のメッセージ本文を作成 } } //Logger.log(forwardBody); //未返信メールの情報を転送 GmailApp.sendEmail(forwardTo, forwardSubject, forwardBody); }

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

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

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

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

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

guest

回答1

0

ベストアンサー

ざっと見た限りでは、 スプレッドシートから取得する部分が全て
.getRange() で終わってるので、これだとセルの中身(値)が取得出来ていません。
.getRange().getValue() に修正を。

あと、log の部分が全部コメントアウトになってるけど、ちゃんとlog 取得して確認した方がいいですよ。

投稿2020/06/17 09:27

sawa

総合スコア3002

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

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

退会済みユーザー

退会済みユーザー

2020/06/17 09:53

丁寧なご回答ありがとうございます。 指摘いただいた内容にて調整してみます。 またコメントアウトになっている件デバックで気づけませんでした。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問