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

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

ただいまの
回答率

91.35%

  • PHP

    15175questions

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

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

受付中

回答 0

投稿 2017/12/04 20:04

  • 評価
  • クリップ 0
  • VIEW 49

RyougoSasaki

score 0

前提・実現したいこと

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/ツール等のバージョンなど)

より詳細な情報

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

質問への追記・修正の依頼

  • asahina1979

    2017/12/05 08:44

    タグ:Google Apps Script をつけたほうがいいかも

    キャンセル

  • asahina1979

    2017/12/05 08:44

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

    キャンセル

  • RyougoSasaki

    2017/12/05 08:59

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

    キャンセル

  • kei344

    2017/12/05 12:23

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

    キャンセル

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

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

ただいまの回答率

91.35%

関連した質問

同じタグがついた質問を見る

  • PHP

    15175questions

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