js 正規表現の先読みと後読み、および非キャプチャグループ化

js 正規表現の先読みと後読み、および非キャプチャグループ化

先読みと後読みをキャプチャグループと組み合わせる

実際のアプリケーション シナリオでは、キャプチャ グループまたは非キャプチャ グループは通常、先読み条件と後読み条件に制限されます。たとえば、数値 12345678 をフォーマットすると、結果は 12,345,678 になります。通常の実装は次のとおりです。

formatSum = '12345678'.replace(/\B(?=(?:\d{3})+(?!\d))/g, ',') とします。

捕獲グループと非捕獲グループ

先読みと後読みを理解するには、まずキャプチャグループと非キャプチャグループを理解する必要がある。

jsでは、

() はキャプチャグループを意味し、() は $n (n は n 番目のキャプチャグループの内容を示す数値) を使用して各グループ内の一致する値を保存します。

(?:) は非キャプチャ グループを表します。キャプチャ グループとの唯一の違いは、非キャプチャ グループに一致する値が保存されないことです。

formatSum 式を例にとると、(?=(?:\d{3})+(?!\d))、(?:\d{3})、(?!\d) はすべてグループであり、2 番目のグループは非キャプチャ グループです。

前を向いて、後ろを振り返り、そして前を向いて後ろをネガティブに振り返る

上記の formatSum 式では、いわゆる先読みと否定先読みである '?=' と '?!' が使用されています。理解しやすくするために、簡単な例から始めましょう。

// 先読み:
A(?=B) //Bより前にAがあるか検索
// ルックバック:
(?<=B)A //Bの後のAを検索
// 否定先読み:
A(?!B) // Bが後に続かないAを探す
// 否定的なルックバック:
(?<!B)A // B が前にない A を検索

formatSum式を振り返ると、(?:\d{3})+(?!\d)は全体式Aとみなされ、つまり、

formatSum = /\B(?=A)/g //ここでAは式であり、実際の文字Aではありません。理解を容易にするためです。

これは、式 A の前の \B に一致することを意味し、\B は文字以外の境界に一致するため、式の全体的な機能は、式 A の前の境界に一致して置き換えることであることがわかります。

\B に対応するのは \b で、文字の境界に一致します。初心者にとって、境界の概念は理解しにくいものです。境界は目に見えない | と考えることができます。長さが 2 以上である文字列には境界が存在します。たとえば、「ab」は「a|b」とみなされますが、| は表示されず、文字列の長さにはカウントされません。

'ab'.replace(/\B/, ',')
// a,b

次に、式の部分 A を見てみましょう: (?:\d{3})+(?!\d) 。

まず、?: は非キャプチャグループを表し、\d{3} は 3 桁を表し、(?:\d{3})+ は 3、6、9、12... 桁を表します。

(?!\d) は否定の先読みであり、数字が続かない (?:\d{3})+ に一致することを意味します。要約すれば:

(?:\d{3})+(?!\d)  

'12345678' 内の数字以外の 3*n (n=1 増分) 桁 (つまり '678'、'345678') に一致します。

結果は次のとおりです。

formatSum = '12345678'.replace(/\B(?=(?:\d{3})+(?!\d))/g, ',')

'12345678' 内の数字ではない 3*n (n=1, n++) 桁の前の非文字境界に一致します。
つまり、「678」と「345678」の前の非文字境界は最終的にコンマに置き換えられます。
つまり、「3」と「6」の前にカンマを追加します

今すぐ

'12345678'.replace(/\B(?=(?:\d{3})+(?!\d))/g, ',') === '12,345,678'
// 真実

要約する

js 正規表現の先読み、後読み、非キャプチャ グループに関するこの記事はこれで終わりです。js 正規表現の先読み、後読み、非キャプチャ グループの詳細については、123WORDPRESS.COM の以前の記事を検索するか、以下の関連記事を引き続き参照してください。今後とも 123WORDPRESS.COM をよろしくお願いいたします。

以下もご興味があるかもしれません:
  • JavaScript における正規表現の実際的な応用の詳細な説明
  • jsは正規表現を使用して年、月、日の例をフィルタリングします
  • js 正規表現の簡単な検証方法
  • Jsは正規表現を使用して文字列から括弧を削除します
  • JavaScriptは正規表現を使用して登録とログインの検証を実装します
  • JavaScript 正規表現の説明

<<:  IE6はmin-widthを実装している

>>:  Ubuntu 20.04 に MySql5.7 をインストールして構成するための詳細なチュートリアル

推薦する

MySQL パフォーマンス チューニングについて知っておくべき 15 個の重要な変数 (要約)

序文: MYSQL は最も人気のある WEB バックエンド データベースです。最近、NOSQL がま...

nodejs + koa + typescript の統合と自動再起動に関する問題

目次バージョンノートプロジェクトを作成する依存関係をインストールするコンテンツの記入src/serv...

LinuxサーバのSSHクラッキング防止方法(推奨)

1. Linuxサーバーは、/etc/hosts.denyを設定して、相手のIPがSSH経由でサー...

VueはOpenLayersを使用してTiandi MapとAmapを読み込み

目次1. 世界地図1. VueにOpenLayersをインストールする2. アマップ1. 世界地図1...

MySQLカバーインデックスの詳しい説明

コンセプトインデックスにクエリ要件を満たすすべてのデータが含まれている場合、それはカバーリング イン...

MySQL が group by をサポートしない場合の解決策の概要

MySQL 5.7.x の最新バージョンをダウンロードしてインストールしました。デフォルトでは、on...

Reactにおける不変値の説明

目次不変の値とは何ですか?不変の値を使用するのはなぜですか? Reactのパフォーマンス最適化は不変...

Firefox の CSS を使用してデータを盗む

0x00 はじめに数か月前、Firefox に脆弱性 (CVE-2019-17016) があること...

ウェブサイトのフッター沈下現象に対する3つの解決策を詳しく解説

背景多くのウェブサイトのデザインは、一般的にコンテンツ+フッターの2つの部分で構成されています。コン...

React ページ ターナーの実装 (フロント エンドとバックエンドを含む)

目次フロントエンド上記のアイデアに従って、ページめくり機能を設計して記述します。バックエンド(Jav...

nginx共有メモリの仕組みの詳細な説明

Nginx の共有メモリは、高いパフォーマンスを実現できる主な理由の 1 つであり、主にファイル キ...

binlog2sql と簡単なバックアップおよびリカバリを使用して mysql8.0.20 を構成するための詳細な手順

目次最初のステップのインストールステップ2: MySQLデータを準備する3 番目のステップは、bin...

レスポンシブ Web をデザインするにはどうすればいいですか?レスポンシブウェブデザインのメリットとデメリット

最近レスポンシブ デザインについて学んでいて、これについていくつか整理してみました。写真の一部はイン...