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

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

新規登録して質問してみよう
ただいま回答率
85.48%
Google Apps Script

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

Q&A

解決済

1回答

1235閲覧

メールで正規表現にマッチした部分のみスプレッドシートに書き出したい。

okarin_555

総合スコア21

Google Apps Script

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

0グッド

0クリップ

投稿2019/07/29 05:05

前提・実現したいこと

メール本文に記載されているスタッフID 6桁、スタッフ名のみをスプレッドシートに書き出したい。

(例)123456 野比のび太
(例)987654 剛田武

のような感じです。
一文を抜き出したら、次のセルに書き出して欲しい。

発生している問題・エラーメッセージ

正規表現にマッチした一文のみであれば、抽出可能でした。
.*?と書くと、数字のみが書き出される。
.*と書くと、スタッフIDとスタッフ名が1つのセルに書き出される。(←理想形に最も近い、複数行かつ別セルに書き出して欲しい。)
*と書くとエラーになってプログラムの実行が出来ませんでした。

該当のソースコード

function searchInoutmail() {
var strTerms ='("【未打刻スタッフ名】")';
var myThreads = GmailApp.search(strTerms,0,30);
var myMsgs =GmailApp.getMessagesForThreads(myThreads);

var arrayMsgs = [];

for (var i =0; i <myMsgs.length;i++){
arrayMsgs[i] =[];
arrayMsgs[i][0] = myMsgs[i][0].getDate();
arrayMsgs[i][1] = myMsgs[i][0].getPlainBody().match("[0-9]{6}.*","g");
arrayMsgs[i][2] = myThreads[i].getPermalink();
}
if(myMsgs.length > 0){
SpreadsheetApp.getActiveSheet().getRange(2,1,i,3).setValues(arrayMsgs);
}
}

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

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

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

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

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

guest

回答1

0

ベストアンサー

数字部分の正規表現は"[0-9]{6}"だけでいいです。
名前部分の正規表現は本当は肯定後読みで表現したいのですが、確かGASは先読みしか認識してくれなかったと思いますので、"[0-9]{6}."で拾ったあとに、replaceで"[0-9]{6}.?"をブランクに置換して利用するのが良いかと思います。

投稿2019/08/08 10:00

hiroshi0240

総合スコア640

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問