###前提・実現したいこと
gmailへspreadsheetへ自動で記載される仕組みを作りたいです。
###発生している問題・エラーメッセージ
問い合わせがあったメールを自動で差配する際、getbodyと入れてメールの本文を転機する際、メールがそのままスプレッドシートの一つのセルに記載されてしまっております。
理想は、メールの個別の項目を個別でスプレッドシートに記載することです。
説明がうまくなくすみません。
みなさまの回答をお待ちしております。
もし、私の説明を読んで理解できなかった方は、お問い合わせください。
何卒、よろしくお願いいたします。
エラーメッセージ
###該当のソースコード
ここにご自身が実行したソースコードを書いてください
function searchContactMail() {
/* Gmailから特定条件のスレッドを検索しメールを取り出す */
var strTerms = 'label:all'; //メール検索条件
var numMailMax = 20000; //取得するメール総数
var numMail = 500; //1度に取得するメール数
var myThreads; //条件にマッチしたスレッドを取得、最大500通と決まっている
var myMsgs; //スレッドからメールを取得する →二次元配列で格納
var valMsgs;
var i = SpreadsheetApp.getActiveSheet().getLastRow();
if(i<numMailMax) {
valMsgs = [];
myThreads = GmailApp.search(strTerms, i, numMail); //条件にマッチしたスレッドを取得、最大500通と決まっている
myMsgs = GmailApp.getMessagesForThreads(myThreads); //スレッドからメールを取得する →二次元配列で格納
/* 各メールから日時、送信元、件名、内容を取り出す*/ for(var j = 0;j < myMsgs.length;j++){ valMsgs[j] = []; valMsgs[j][0] = myMsgs[j][0].getFrom(); valMsgs[j][1] = myMsgs[j][0].getReplyTo(); valMsgs[j][2] = myMsgs[j][0].getTo(); valMsgs[j][3] = myMsgs[j][0].getDate(); valMsgs[j][4] = myMsgs[j][0].getSubject(); valMsgs[j][5] = myMsgs[j][0].getBody(); function myFunction() {
//これメールと仮定
var msg = "[会社名]\n[お名前]\n[電話番号]\n[メールアドレス]\n[ホームページURL]\n[国名]\n[ご利用用途]\n[ドローンの有無]\n[過去のドローン測量実施有無]\n[ご使用のSfMソフト]\n[ご興味のある機能]\n[ご利用のPCのCPU]\n [ご利用のPCメモリ(RAM)]\n";
//メール本文を改行で分けて配列に
var array = msg.split("\n");
//抜き出したいデータの連想配列
var data = {'[会社名] ':'', '[お名前] ':'', '[電話番号] ':'', '[ メールアドレス ]':'', '[ホームページURL] ':'', '[国名] ':'','[ご利用用途] ':'','[ご使用中のSfMソフト] ':',''[ご興味のある機能] ':',''[ご利用のPCのCPU] ':',';'[ご利用のPCメモリ(RAM)]':''};
}
for (key in data){
for (var i = 0; i < array.length; i++){
//分解したメールの本文にkeyの文字列が含まれてたら処理を行う
if (array[i].indexOf(key) != -1){
//連想配列にデータを入れる
data[key] = array[i].replace(key, '');
Logger.log(data[key]);
}
}
}
}
} /* スプレッドシートに出力 */ if(myMsgs.length>0){ SpreadsheetApp.getActiveSheet().getRange(i + 1, 1, j, 6).setValues(valMsgs); //シートに貼り付け }
}
}
###試したこと
課題に対してアプローチしたことを記載してください
この問題を解決するためにおそらくif文と分岐を用いると考えたため、if文のプログラミングを追加して行っていたのですが、どれもうまく行っていない状況です。
###補足情報(言語/FW/ツール等のバージョンなど)
より詳細な情報
あなたの回答
tips
プレビュー