日々の雑感

EC運営でよくある注文番号のメールのラベル付けの悩みをGASで解決

投稿日:

新しいGメールを受信したとき、本文中に過去メールと同じ注文番号があったなら、その過去メールにつけたラベルと同じにする・・・言葉での説明さえも難しい・・・ということがしたかったのですが、難しすぎてフィルタの限界を超えるので、GASのスクリプト制作をChatGTPに頼んだら、すぐにできた。
素晴らしい。。

// Gmailで受信したラベルが全くついていない新メールの本文に「(例)ご注文番号: 121220」という内容があれば、

// 過去に受信したメールのタイトル「(例)ご注文(#121220)」を検索し、ヒットしたら、過去メールについているラベルと同じものを新メールにつける

// ラベルを新しいメールに適用する際に「amazon」「other」のラベルが含まれていたら除外する

function applyLabelsToNewEmails() {

  // 次の条件を満たすメールスレッドを最大50件取得します:

  // 1.「受信トレイ」

  // 2.amazon 等のラベルは付いていない

  // const threads = GmailApp.search("(label:inbox OR label:楽天 OR label:Yahoo) -label:{楽天 Yahoo} is:unread", 0, 50);// 最大50件のスレッドを取得

const threads = GmailApp.search("(label:inbox) -label:{amazon other} is:unread ", 0, 50);// 最大50件のスレッドを取得

  threads.forEach((thread) => {

    const messages = thread.getMessages();

    messages.forEach((message) => {

        const body = message.getPlainBody();

        const subject = message.getSubject();

        // メール本文またはタイトルに注文番号が含まれているかチェック

        const bodyMatch = body.match(/ご注文番号:\s*(\d+)/);

        const subjectMatch = subject.match(/\[(\d+)\]/);

        const orderNumber = bodyMatch ? bodyMatch[1] : subjectMatch ? subjectMatch[1] : null;

// console.log(orderNumber)

        if (orderNumber) {

          // 過去のメールを検索

          const searchQuery = `subject:"ご注文(#${orderNumber})" OR [受注番号] ${orderNumber}"`;

          const pastThreads = GmailApp.search(searchQuery);

// console.log(searchQuery)

          if (pastThreads.length > 0) {

            const pastLabels = pastThreads[0].getLabels();

            // 除外するラベルリスト

            const excludedLabels = ["amazon"];

            // ラベルを新しいメールに適用(除外リストを考慮)

            pastLabels.forEach((label) => {

              if (!excludedLabels.includes(label.getName())) {

                thread.addLabel(label);

              }

            });

          }

        }

    });

  });

}

-日々の雑感

執筆者:

関連記事

no image

メンタルヘルス

今、朝の4時。 さっき、夢を見てきた。 以下、夢の中身。 自分は、中学生か、高校生。 場所はグラウンド、運動会。 自分は黄団、しかし、黄色い帽子と黄色い鉢巻を家に忘れた。 目立っているだろうな、笑われ …

no image

佐々木希VS板野友美

「ウィルコムをやめてイーモバイルの音声プランにしたらどうかと思うんだけど」 「イヤ。ただでさえ友達や親戚にウィルコムってマイナーに思われているのに、聞いたこともないイーモバイルって何それ? 反対」 「 …

no image

GW

GWは、のとじま水族館と、七尾の青柏祭(せいはくさい)に行った。 のとじま水族館は、5月5日は子供の日で、子供無料。 今年できたばかりのイルカの泳ぐトンネル水槽が、目玉。 実際来てみると、大迫力で、こ …

no image

歯医者

今日は休み、午後から歯医者。 家から最も近くにある歯科医をチョイスして、そこに行っている。 前回は、取れた銀歯の装着と歯石の除去をしてもらった。 本日は2回目、前回と同じで担当は院長らしき若先生ではな …

no image

風邪

頭が痛い喉が痛い咳が出る。 早朝、気分が悪くて目が覚めた。 5時。 8時に家を出る自分にとって、そのまま寝るにも起きるにも、ちょっと中途半端。 結局、起きて朝食を食べて薬を飲んだ。 で、そのままこうし …