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

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

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

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

Gmail

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

Google Apps Script

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

Q&A

解決済

1回答

1700閲覧

Googleスプレッドシートで書いた内容を、Gmailの下書きに記載して日報の下書きを作成したいです。

masashi-vba

総合スコア2

Google スプレッドシート

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

Gmail

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

Google Apps Script

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

0グッド

1クリップ

投稿2020/04/25 16:21

前提・実現したいこと

日報の下書きを作成するスクリプトを作成したいのですが、うまく動いてくれないので質問させてください。
GoogleスプレッドシートのB2~B6に記載されている内容を基に、Gmailの下書きにそれらを記入させたいです。
具体的には下記のような感じです。19行目のGmailApp.createDraftの行に問題がありそうです。

よろしくお願い致します。

B2:Toのメールアドレス
B3:タイトル(件名)
B4:本文の冒頭(「お疲れ様です」など)
B5:本文(メールの内容)
B6:本文の締め(「よろしくお願い致します」など)

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

Exception: 無効なメール: Range at createDraft(コード:19:12)

該当のソースコード

GAS

1function createDraft() { 2 var app,sheet 3 app = SpreadsheetApp 4 sheet = app.getActiveSheet() 5 6 var date = new Date() 7 var tsuki = date.getMonth()+1; 8 var hi = date.getDate() 9 10 11 var to, subject, body 12 to = sheet.getRange(2,2) 13 subject = tsuki + '/' + hi + sheet.getRange(3,2); 14 body = ''; 15 body += sheet.getRange(4,2) + '\n\n'; 16 body += sheet.getRange(5,2) + '\n\n'; 17 body += sheet.getRange(6,2); 18 19 GmailApp.createDraft(to,subject,body); 20 21}

試したこと

セミコロンの位置や改行を入れてみましたが改善されませんでした。
to, subject, bodyの間のスペースを入れても外しても変わりませんでした。
こういう時に何を試せばわからないことのきっかけが見えてくるかまだよく知らないので、試せたことはこの程度でした...。

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

元々のスクリプトはgetDataRangeや2次元配列を活用したもので、それを加工して使用ようとしたものが上記のものです。
元のスクリプトとURLは下記のものです。

URL
https://tonari-it.com/gas-gmail-create-draft/

スクリプト
function createDraft() {
const values = SpreadsheetApp.getActiveSheet().getDataRange().getValues();
const to = values[1][1];
const subject = values[2][1];
let body = '';
body += values[3][1] + '\n\n';
body += values[4][1] + '\n\n';
body += values[5][1];

GmailApp.createDraft(to, subject, body);
}

よろしくお願い致します。

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

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

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

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

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

CHERRY

2020/04/25 23:15

まずは、変数の値が正しいかを確認するところからでしょうか。 createDraft を実行する前に to, subject, body を表示してみるとどのような値が入っていますか?
masashi-vba

2020/04/26 12:22

ご回答ありがとうございます。 仰る通りcreateDraftの前にconsole.log(to);などで変数に何が入っているかを確認したところ、ちゃんと値が入っていなかったみたいです。 変数に値を入れる方法を学習しなおして、getRange(2,2)で終わっていたところをgetRange(2,2).getValue()にしたところ、うまくいくようになりました。 ありがとうございました!
guest

回答1

0

ベストアンサー

https://developers.google.com/apps-script/reference/gmail/gmail-app#createDraft(String,String,String)

toに指定するのは文字列である必要がありますが、今のコードだとgetRangeした結果を渡しているので、stringではなく、Rangeオブジェクトが渡されています。

文字列に変換するには、getValue か getValuesでできるかと思います。

投稿2020/04/26 01:26

moya_dev

総合スコア183

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

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

masashi-vba

2020/04/26 12:25

ご回答ありがとうございます。 getRange(2,2)の箇所をgetRange(2,2).getValue()にしたところうまくいくようになりました。 恥ずかしながらまだ学習し始めたばかりで、getRange(2,2)だけではセル内の数値を変数に代入してこれないんですね。 moyashidaisukeさんのコメントのおかげでそこに気づけたので、こちらをベストアンサーとさせて頂きます。ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問