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

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

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

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

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

解決済

『GAS』Gmailの文章をを正規表現で抜くには

nezumimuzen
nezumimuzen

総合スコア19

Google スプレッドシート

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

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。

2回答

0評価

0クリップ

4102閲覧

投稿2020/07/02 13:50

編集2020/07/05 11:27

前提・実現したいこと

google app scriptを使って下記のメールの内容をスプレッドシートへ正規表現する方法について、タイトル部分は

var reg title = new RegExp('【 タイトル 】 ' + '.*');

で抜き出すことができたのですが、メモ部分の
【 メモ 】
から
===================
までの下記のような太文字部分を抽出したいのですがやり方がわかりません。
改行を含む文字の抽出方法を調べたところ[\s\S]*を使うみたいなのですが試してみても正しく動作しません。

また、シートへ書き出す際は
sheet.getRange(row,1).setValue(Memo);
を使って書き出しています。

メール 内容

【 タイトル】 title
【 メモ 】 aaa
aaa
aaa

===================

タイトルのテキストを抽出するコード

google

var reg title = new RegExp('【 タイトル 】 ' + '.*'); var title = body.match(regtitle)[0].replace('【 タイトル 】 ', '').replace('\r', '');

(問題あり)メモ部分のコードを抽出するコード

google

var Memo = new RegExp('"【 メモ 】 [\s\S]*="');

7/4追記

var sheet = SpreadsheetApp.getActiveSheet(); var data = sheet.getRange(7, 21, sheet.getLastRow() + 1).getValues(); function getMail3(){ var objSpreadsheet = SpreadsheetApp.getActiveSpreadsheet(); // シート名を記入。 var objSheet = objSpreadsheet.getSheetByName("シート取り込み”);  var sheet = SpreadsheetApp.setActiveSheet(objSheet); var start = 0; // 取得するメールの最大件数 var max = 100; // Gmailのラベル名 var threads = GmailApp.search('label:シート取り込み is:unread',start,max);   var Messages = GmailApp.getMessagesForThreads(threads); var row = sheet.getLastRow() + 1; // 見出しがあるためシートの1行目を固定 sheet.setFrozenRows(1); // メールから日時、要項を取り出す// for(var i = 0; i < Messages.length; i++) { for(var j = 0; j < Messages[i].length; j++) { var body = Messages[i][j].getPlainBody(); var reg title = new RegExp('【 タイトル 】 ' + '.*'); var title = body.match(regtitle)[0].replace('【 タイトル 】 ', '').replace('\r', ''); var Memo = new RegExp('【 ご要望など(任意) 】 '+'[\s\S]*?'+'='); var Memotext = body.match(Memo)[0]; // 同じメールを読み込まないように、メッセージを既読にする threads[i].markRead(); // それぞれの項目をセルを指定してスプレッドシートへ転記 sheet.getRange(row,1).setValue(title); sheet.getRange(row,2).setValue([Memotext]); row++ } } }

7/4追記エラーメッセージ

TypeError: Cannot read property '0' of null(行 35、ファイル「Mail-import」)

良い質問の評価を上げる

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

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

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

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

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

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

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

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

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

asahina1979

2020/07/02 14:02

google app script ならば java は関係ないです。
asahina1979

2020/07/02 14:02

java なら javascript は関係ないです
nezumimuzen

2020/07/02 14:11

Google Apps ScriptとJavaの知識が通ずるとどこかで読んだことがあったため誤解を生むような表記をしてしまいました。 申し訳ございません、、、

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

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

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

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

Google スプレッドシート

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

Google Apps Script

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

正規表現

正規表現とは特定の文字列によるパターンマッチングを行う際に用いられる宣言型プログラミングです。