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

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

ただいまの
回答率

87.35%

メールに記載された改行を含む問い合わせ文章を抽出したいです。

受付中

回答 1

投稿

  • 評価
  • クリップ 1
  • VIEW 1,697

score 5

メールに記載された改行を含む問い合わせ文章を抽出したいです。

【自由記入欄】に入力された問い合わせ文章を抜き出したいのですが、この場合はfetchData(body, )をどのように入力すればいいのでしょうか?

'【自由記入欄】' + '[\\s\\S]*?' + '==========================='

上記のような範囲指定などいくつかやってみたのですが表示されないため困っています。

初心者のため以前いただいた回答や調べて出てきたものをつぎはぎしながら作っている状態なのですが、どうぞよろしくお願いいたします。

メール内容は以下の通りです。

【 お名前 】 ○○○○
【 フリガナ 】 ○○○○

~中略~

【 自由記入欄 】
問い合わせ文章がここに表示されます。
問い合わせ文章がここに表示されます。
問い合わせ文章がここに表示されます。

===========================
function q219571(){
    const mailQuery = ',subject:"お問い合わせ"'; //メールの件名
    const threads = GmailApp.search(mailQuery);
    const messages = GmailApp.getMessagesForThreads(threads).reduce(function (a,h) { return a.concat(h.map(mailToArray))},[]);
    const sheet = SpreadsheetApp.getActiveSheet();
    const r = sheet.getLastRow();
    sheet.getRange(r+1, 1, messages.length, 15).setValues(messages);
}

function mailToArray(m) {
    const body = m.getPlainBody();
    return [
        fetchData(body, '送信された日時:', '\r'), //送信された日時を抽出

       fetchData(body, '【 お名前 】', '\r'), //氏名を抽出
     fetchData(body, '【 フリガナ 】', '\r'), //フリガナを抽出

     fetchData(body, '【 ご住所 】', '\r'), //郵便番号を抽出
     fetchData(body,  '(東京都|北海道|(?:京都|大阪)府|.{2,3}県)','\r'), //県名を抽出
     fetchData(body, '[府|都|道|県]', '\r'), //市以降の住所を抽出

     fetchData(body, '【 電話番号 】', '\r'), //電話番号を抽出
     fetchData(body, '【 メールアドレス 】', '\r'), //メールアドレスを抽出

     fetchData(body, '⒈', '\r'), //きっかけを抽出
           fetchData(body, '⒉', '\r'), //きっかけを抽出
           fetchData(body, '⒊', '\r'), //きっかけを抽出
           fetchData(body, '⒋', '\r'), //きっかけを抽出
           fetchData(body, '⒌', '\r'), //きっかけを抽出
           fetchData(body, '⒍', '\r'), //きっかけを抽出

     fetchData(body, '', '\r'), //問い合わせ文を抽出
    ];
}

function fetchData(str, pre, suf) {
    const res = str.match(new RegExp(pre + '(.*?)' + suf));
    return res === null ? '' : res[1];
}
  • 気になる質問をクリップする

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • papinianus

    2019/10/30 00:14

    コードをタダで書いてくれという作業依頼なのですから、下手に省略せず、どういうテンプレートでどういう部分が固定でどこが可変で何を取得したいかをメールの文面の実例で可能な限り具体的に示してください。

    キャンセル

回答 1

0

正規表現のフラグについて、調べてみてください。
正規表現 - JavaScript | MDN

具体的にはこんな感じでしょうか。

var body = function() { /*
`【 お名前 】 ○○○○
【 フリガナ 】 ○○○○

~中略~

【 自由記入欄 】
問い合わせ文章がここに表示されます。
問い合わせ文章がここに表示されます。
問い合わせ文章がここに表示されます。

===========================
`;
*/ }.toString().split('\n').slice(1, -1).join('\n');


function fetchData(str, pre, suf) {
    const res = str.match(new RegExp(pre + '(.*?)' + suf, 's'));
    return res === null ? '' : res[1];
}

var freeText = fetchData(body, "【 自由記入欄 】", '===========================');
console.log("freeText = '" + freeText + "'");

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2019/10/29 17:21 編集

    回答ありがとうございます!コピペさせていただいたのですが、const res = str.match(new RegExp(pre + '(.*?)' + suf, 's')); の部分に「SyntaxError: 正規表現の後のフラグが無効です。」と出てしまいました。
    コードのいちばん下に貼り付けたのですが、位置が間違っているのでしょうか?それとも書いていただいたものを基に全体的に修正したほうがいいでしょうか?

    キャンセル

  • 2019/10/29 17:53

    いえ。sはgasではサポートされていません。なので前回回答の案になったんですが。

    キャンセル

  • 2019/10/29 19:45

    失礼しました。サポートされてないんですか。gasが古いバージョンのJavaScriptしかサポートしていないのは知っていたのですが、sフラグはサポートされていると思い込んでいました。ご指摘ありがとうございます。

    キャンセル

  • 2019/10/29 23:31

    厳密には確認できていません。が、私もこの案は思いついて試したのですが、どうやっても通らないのでサポートされていないと思ってます。
    https://developer.mozilla.org/ja/docs/Web/JavaScript/Reference/Global_Objects/RegExp
    からECMAをみるとECMA 2015 ですらdotAllはサポートしてないので無理っぽいです。(gasはECMA 5.1未満なので)
    参考として[\s\S]+といった回避も使えませんでした。

    キャンセル

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

  • ただいまの回答率 87.35%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

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