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

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

新規登録して質問してみよう
ただいま回答率
85.50%
PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

Q&A

0回答

1646閲覧

gmailのメールの自動差配の仕組みを作っております

RyougoSasaki

総合スコア6

PHP

PHPは、Webサイト構築に特化して開発されたプログラミング言語です。大きな特徴のひとつは、HTMLに直接プログラムを埋め込むことができるという点です。PHPを用いることで、HTMLを動的コンテンツとして出力できます。HTMLがそのままブラウザに表示されるのに対し、PHPプログラムはサーバ側で実行された結果がブラウザに表示されるため、PHPスクリプトは「サーバサイドスクリプト」と呼ばれています。

0グッド

0クリップ

投稿2017/12/04 11:04

###前提・実現したいこと
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/ツール等のバージョンなど)
より詳細な情報

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

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

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

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

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

退会済みユーザー

退会済みユーザー

2017/12/04 23:44

タグ:Google Apps Script をつけたほうがいいかも
退会済みユーザー

退会済みユーザー

2017/12/04 23:44

コードはマークダウンで(わからない場合はヘルプを、読んで)
RyougoSasaki

2017/12/04 23:59

ご回答頂きましてありがとうございます。
kei344

2017/12/05 03:23

ここは「質問への追記・修正の依頼」ですので、「回答」ではありません。質問本文は編集することが可能なので、その依頼をされています。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだ回答がついていません

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

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

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問