Google Apps Scriptで正規表現でマッチした文字列から不要な部分を削除する

trim

photo credit: Symic 000ElmTreeVitality via photopin (license)

みなさん、こんにちは!
タカハシ(@ntakahashi0505)です。

Google Apps Scriptでフォーム送信メールからデータを抽出してスプレッドシートに登録するツールを作成しております。

前回の記事はコチラです。

Google Apps Scriptで正規表現を使って必要な情報を抽出する最も簡単なスクリプト
Google App Scriptを使ってGmailで届いたフォーム送信情報をスプレッドシートに蓄積する方法の初回。正規表現とは何か、またGASで正規表現により文字列を抽出する最も簡単なスクリプトを紹介します。

正規表現というテクニックを使って文字列からデータを抽出する方法をお伝えしました。

例えば「名前:鈴木」「年齢:30才」という文字列のパターンを拾うことができましたが、本当に欲しいのは「鈴木」だったり、「30」だったりするわけですね。

ですから、正規表現で文字列を抽出した場合は、いらない部分をザクザク削る処理が必要になるのが一般的です。

ということで、今回はGASで正規表現で抽出した文字列から、欲しいデータのみを取り出す方法をお伝えします。

では、いってみましょう。

スポンサーリンク

前回のおさらい

では、まず前回のおさらいから。

作成したスクリプトはコチラ。

function myFunction() {
  const str = '高橋様rお世話になっております。rr名前:鈴木r年齢:30才rr以上です。';
  console.log(str.match(/名前:.*?r/g));  
  console.log(str.match(/年齢:.*?才/g));
}

冒頭に用意したstrはメール本文を意識した文字列ですが、そこから以下を抽出することができます。

  • 「名前:」ではじまって「r」(復帰)で終わる文字列のパターン、つまり「名前:鈴木n」
  • 「年齢:」ではじまって「才」で終わる文字列のパターン、つまり「年齢:30才」

今回は、ここから「鈴木」または「30」だけを残して不要な部分を削っていく処理を作っていきたいと思います。

正規表現でマッチした文字列の不要な部分を削除する

replaceメソッドで部分文字列を削除する

文字列の一部び削除はreplaceメソッドを使って実現することができます。

本来、replaceメソッドは文字列の部分文字列を置換するメソッドで以下のように書きます。

文字列.replace(部分文字列, 置換文字列)

この置換文字列を空文字(”)とすることで、部分文字列の削除と同様の処理となるというわけです。

文字列.replace(部分文字列, ”)

不要な部分を削除する処理を入れたスクリプト

これにより、前述のスクリプトをいじってみると、以下のようになります。

function myFunction() {
  const str = '高橋様rお世話になっております。rr名前:鈴木r年齢:30才rr以上です。';
  console.log(str.match(/名前:.*?r/g)[0].replace('名前:', '').replace('r', ''));  
  console.log(str.match(/年齢:.*?才/g)[0].replace('年齢:', '').replace('才', ''));  
}

matchメソッドの後の部分で「[0]」としているのは、配列から最初の要素を取り出すためです。

matchメソッドの戻り値は、パターンにマッチした文字列の配列ですからね。

ですが…ちょいと冗長ですよね。同じような処理が続いちゃっているので、整理していきましょう。

正規表現による抽出とデータの取り出しをする関数

newによる正規表現の生成

その事前準備として、正規表現の生成方法として、正規表現リテラルとは別の方法をお伝えしておきます。

JavaScriptで正規表現はRegExpオブジェクトというオブジェクトですので、newキーワードで生成をすることができます。

new RegExp(正規表現パターン, フラグ)

引数の正規表現は文字列で指定できますので、変数を使うことができます。フラグは前回の記事でお伝えしたものと同じです。

パターンマッチを抽出し必要なデータを取り出す関数

それを踏まえて、文字列strから最初の文字列preではじまり、最後の文字列sufで終わるというパターンマッチを抽出し、さらに必要なデータのみを取り出す関数fetchDataを作りました。

以下の関数fetchDataです。

function myFunction() {
  const fetchData = (str, pre, suf) => {
    const reg = new RegExp(pre + '.*?' + suf, 'g');
    const data = str.match(reg)[0]
      .replace(pre, '')
      .replace(suf, '');
    return data;  
  };
 
  const str = '高橋様rお世話になっております。rr名前:鈴木r年齢:30才rr以上です。';
  console.log(fetchData(str, '名前:', 'r'));
  console.log(fetchData(str, '年齢:', '才'));
}

これを実行すると、以下のようなログ出力が得られます。

GASで正規表現を使ってデータを抽出したログ

まとめ

以上、Google Apps Scriptで正規表現でマッチした文字列から不要な部分を削除する方法についてお伝えしました。

  • replaceメソッドで文字列の部分文字列を削除する
  • newキーワードによる正規表現の生成

ちょいと地味な内容ですが、けっこう便利ですよ…!

では、次回は実際にGmailのメッセージからデータを抽出していきますね。

Google Apps ScriptでGmailの受信メールから正規表現でデータを抽出する
Google Apps Scriptでフォーム送信メールからデータを抽出してスプレッドシートに登録するツールを作成しています。今回はGmailに届いたメールから正規表現でデータを抽出するスクリプトを紹介します。

どうぞお楽しみに!

連載目次:GASで正規表現を使ってデータを抽出&登録

正規表現を使うとGoogle Apps ScriptでメールやHTMLドキュメントからデータを抽出することができます。本シリーズでは、フォーム送信の通知メールからデータを抽出してスプレッドシートに追加するツールの作成を目指します。
  1. Google Apps Scriptで正規表現を使って必要な情報を抽出する最も簡単なスクリプト
  2. Google Apps Scriptで正規表現でマッチした文字列から不要な部分を削除する
  3. Google Apps ScriptでGmailの受信メールから正規表現でデータを抽出する
  4. Google Apps Scriptでメールから正規表現で抽出したデータをスプレッドシートに蓄積する方法
  5. Google Apps ScriptでGmailのメッセージIDを取得する方法
  6. Google Apps Scriptでスプレッドシートの列データを配列として取得する方法
  7. GASで二次元配列に特定の要素が含まれているかを判定する方法
  8. GASでフォーム送信メールからデータを取得してスプレッドシートに蓄積するツールの完全版

コメント

  1. 川田通広 より:

    これは一番求めていた機能です。
    ありがとうございました。

',b.captions&&s){var u=J("figcaption");u.id="baguetteBox-figcaption-"+t,u.innerHTML=s,l.appendChild(u)}e.appendChild(l);var c=J("img");c.onload=function(){var e=document.querySelector("#baguette-img-"+t+" .baguetteBox-spinner");l.removeChild(e),!b.async&&n&&n()},c.setAttribute("src",r),c.alt=a&&a.alt||"",b.titleTag&&s&&(c.title=s),l.appendChild(c),b.async&&n&&n()}}function X(){return M(o+1)}function D(){return M(o-1)}function M(e,t){return!n&&0<=e&&e=k.length?(b.animation&&O("right"),!1):(q(o=e,function(){z(o),V(o)}),R(),b.onChange&&b.onChange(o,k.length),!0)}function O(e){l.className="bounce-from-"+e,setTimeout(function(){l.className=""},400)}function R(){var e=100*-o+"%";"fadeIn"===b.animation?(l.style.opacity=0,setTimeout(function(){m.transforms?l.style.transform=l.style.webkitTransform="translate3d("+e+",0,0)":l.style.left=e,l.style.opacity=1},400)):m.transforms?l.style.transform=l.style.webkitTransform="translate3d("+e+",0,0)":l.style.left=e}function z(e){e-o>=b.preload||q(e+1,function(){z(e+1)})}function V(e){o-e>=b.preload||q(e-1,function(){V(e-1)})}function U(e,t,n,o){e.addEventListener?e.addEventListener(t,n,o):e.attachEvent("on"+t,function(e){(e=e||window.event).target=e.target||e.srcElement,n(e)})}function W(e,t,n,o){e.removeEventListener?e.removeEventListener(t,n,o):e.detachEvent("on"+t,n)}function G(e){return document.getElementById(e)}function J(e){return document.createElement(e)}return[].forEach||(Array.prototype.forEach=function(e,t){for(var n=0;n","http://www.w3.org/2000/svg"===(e.firstChild&&e.firstChild.namespaceURI)}(),m.passiveEvents=function i(){var e=!1;try{var t=Object.defineProperty({},"passive",{get:function(){e=!0}});window.addEventListener("test",null,t)}catch(n){}return e}(),function a(){if(r=G("baguetteBox-overlay"))return l=G("baguetteBox-slider"),u=G("previous-button"),c=G("next-button"),void(d=G("close-button"));(r=J("div")).setAttribute("role","dialog"),r.id="baguetteBox-overlay",document.getElementsByTagName("body")[0].appendChild(r),(l=J("div")).id="baguetteBox-slider",r.appendChild(l),(u=J("button")).setAttribute("type","button"),u.id="previous-button",u.setAttribute("aria-label","Previous"),u.innerHTML=m.svg?f:"<",r.appendChild(u),(c=J("button")).setAttribute("type","button"),c.id="next-button",c.setAttribute("aria-label","Next"),c.innerHTML=m.svg?g:">",r.appendChild(c),(d=J("button")).setAttribute("type","button"),d.id="close-button",d.setAttribute("aria-label","Close"),d.innerHTML=m.svg?p:"×",r.appendChild(d),u.className=c.className=d.className="baguetteBox-button",function n(){var e=m.passiveEvents?{passive:!1}:null,t=m.passiveEvents?{passive:!0}:null;U(r,"click",x),U(u,"click",E),U(c,"click",C),U(d,"click",B),U(l,"contextmenu",A),U(r,"touchstart",T,t),U(r,"touchmove",N,e),U(r,"touchend",L),U(document,"focus",P,!0)}()}(),S(e),function s(e,a){var t=document.querySelectorAll(e),n={galleries:[],nodeList:t};return w[e]=n,[].forEach.call(t,function(e){a&&a.filter&&(y=a.filter);var t=[];if(t="A"===e.tagName?[e]:e.getElementsByTagName("a"),0!==(t=[].filter.call(t,function(e){if(-1===e.className.indexOf(a&&a.ignoreClass))return y.test(e.href)})).length){var i=[];[].forEach.call(t,function(e,t){var n=function(e){e.preventDefault?e.preventDefault():e.returnValue=!1,H(i,a),I(t)},o={eventHandler:n,imageElement:e};U(e,"click",n),i.push(o)}),n.galleries.push(i)}}),n.galleries}(e,t)},show:M,showNext:X,showPrevious:D,hide:j,destroy:function e(){!function n(){var e=m.passiveEvents?{passive:!1}:null,t=m.passiveEvents?{passive:!0}:null;W(r,"click",x),W(u,"click",E),W(c,"click",C),W(d,"click",B),W(l,"contextmenu",A),W(r,"touchstart",T,t),W(r,"touchmove",N,e),W(r,"touchend",L),W(document,"focus",P,!0)}(),function t(){for(var e in w)w.hasOwnProperty(e)&&S(e)}(),W(document,"keydown",F),document.getElementsByTagName("body")[0].removeChild(document.getElementById("baguetteBox-overlay")),w={},h=[],o=0}}})
タイトルとURLをコピーしました