搜尋
首頁後端開發C#.Net教程C#之正規表示式介紹

C#之正規表示式介紹

Nov 23, 2019 pm 05:15 PM
c#正規表示式

本文整理C#正規表示式的元字符,正規表示式是由字符構成的表達式,每個字符代表一個規則,表達式中的字符分為兩種類型:普通字符和元字符。普通字符是指字面含義不變的字符,按照完全匹配的方式匹配文本,而元字符具有特殊的含義,代表一類字符。

C#之正規表示式介紹

把文字看作是字元流,每個字元放在一個位置上,例如,正規表示式“Room\d\d\d”,前面四個字符Room是普通字符,後面的字符\是轉義字符,和後面的字符d組成一個元字符\d,表示該位置上有任意一個數字。

用正規表示式的語言來描述是:正規表示式 「Room\d\d\d」共捕獲7個字符,表示「以Room開頭、以三個數字結尾」的一類字串,我們把這一類字串稱作一個模式(Pattern),也稱作是一個正則。

一,轉義字符

轉義字符是\,把普通字符轉義為具有特殊含義的元字符,常用的轉義字元有:

  • \t:水平製表符
  • \v:垂直製表符
  • \r:回車
  • \n:換行
  • \\:表示字元\,也就說,把轉義字元\ 轉義為普通的字元\
  • \":表示字元",在C#中,雙引號用於定義字串,字串包含的雙引號用\" 來表示

二,字元類別

在進行正規比對時,把輸入文字看成有順序的字符流,字符類元字符匹配的對像是字符,並會捕獲字符。所謂捕獲字符是指,一個元字符捕獲的字符,不會被其他元字符匹配,後續的元字符只能從剩下的文字中重新匹配。

常用的字元類別元字元:

  • #[ char_group]:匹配字元組中的任一個字元
  • [^char_group]:符合字元組以外的任一字元
  • [first-last]:符合從first到last的字元範圍中的任一個字符,字符範圍包括first和last。
  • .   :通配符,匹配除\n之外的任意一個字符
  • ##\w:匹配任一個單字(word)字符,單字字符通常是指A-Z、a-z和0-9
  • \W:匹配任意一個非單字字符,是指除A-Z 、a-z和0-9以外的字元
  • \s:符合任一個空白字元
  • \S:符合任一個非空白字元
  • \d:符合任一個數字字元
  • \D:符合任一個非數字字元
注意,轉義字符也屬於字符類元字符,在進行正則匹配時,也會捕獲字符。

三,定位符##定位符匹配(或捕獲)的對像是位置,它根據字符的位置來判斷模式匹配是否成功,定位符不會捕獲字符,是零寬的(寬度為0),常用的定位符有:

    ^
  • :預設情況下,符合字串的起始位置;在多行模式下,符合每行的開始位置;
  • $
  • #:預設情況下,符合字串的結束位置,或字串結尾的\n之前的位置;在多行模式下,符合每行結束之前的位置,或每行結尾的\n之前的位置。
  • \A
  • :符合字串的起始位置;
  • \Z
  • :符合字串的結束位置,或字串結尾的\n之前的位置;
  • \z
  • :符合字串的結束位置;
  • \G
  • :符合上一個符合結束的位置;
  • \b
  • :符合一個單字的開始或結束的位置;
  • #\B
  • :符合一個單字的中間位置;
  •  

四,量詞、貪婪與懶惰量詞是指限定前面的一個正規出現的次數,量詞分為兩種模式:貪婪模式和懶惰模式,貪婪模式是指匹配盡可能多的字符,而懶惰模式是指匹配盡可能少的字符。預設情況下,量詞處於貪婪模式,在量詞的後面加上?來啟用懶惰模式。

  • *:出現0次或多次
  • :出現1次或多次
  • ##?#:出現0次或1次
  • {n}:出現n次
  • {n,}:出現至少n次
  • {n,m}:出現n到m次
注意,出現多次是指前面的元字元出現多次,例如,\d {2} 等價於\d\d,只是出現兩個數字,並不要求兩個數字是相同的。要表示相同的兩個數字,必須使用分組來實現。

五,分組和捕捉​​字元

()  括號不僅決定表達式的範圍,還建立分組,()內的表達式就是一個分組,引用分組表示兩個分組匹配的文字是完全相同的。定義一個分組的基本語法:

(

pattern)

#該類型的分組會捕獲字符,所謂捕獲字符是指:一個元字符捕獲的字符,不會被其他元字符匹配,後續的元字符只能從剩餘的文本中重新匹配。

1,分組編號和命名

預設情況下,每個分組自動分配一個組號,規則是:從左向右,按分組左括號的出現順序進行編號,第一個分組的組號為1,第二個為2,以此類推。也可以為分組指定名稱,該分組稱為命名分組,命名分組也會被自動編號,編號從1開始,逐一加1,為分組指定名稱的語法是:

(? name > pattern)

通常來說,分組分為命名分組和編號分組,引用分組的方式有:

    透過分組名稱來引用分組:\k
  • 透過分組編號來引用分組:\ number
注意,分組只能後向引用,也就是說,從正規表示式文字的左邊開始,分組必須先定義,然後才能在定義之後面引用。

在正規表示式裡引用分組的語法為“\number”,例如“\1”代表與分組1 匹配的子字串,“\2”代表與分組2 匹配的字符串,以此類推。

例如,對於 ".*?\1>" 可以匹配 

valid

,在引用分組時,分組對應的文本是完全相同的。

2,分組建構器

分組建構方法如下:

  • (pattern):捕捉符合的子表達式,並為分組分配一個組號
  • (? pattern):將匹配的子表達式捕獲到命名的分組中
  • #(?:pattern):非捕獲的分組,並未分組分配一個組號
  • #(?> pattern):貪婪分組

3,貪婪分組

貪婪分組也稱作非回溯分組,該分組禁用了回溯,正則表達式引擎將盡可能匹配輸入文本中的字元。如果無法進行進一步的匹配,則不會回溯嘗試進行其他模式匹配。

(?> pattern )

#4,二選一

##|

的意思是或,配對兩者中的任一個,注意,把左右兩邊的表達式分成兩部分。 <pre class="brush:php;toolbar:false">pattern1 | pattern2</pre>

六,零寬斷言#零寬是指寬度為0,符合的是位置,所以符合的子字串不會出現在配對結果中,而斷言是指判斷的結果,只有斷言為真,才算匹配成功。

對於定位符,可以匹配一句話的開始、結束(^ $)或匹配一個單字的開始、結束(\b),這些元字元只匹配一個位置,指定這個位置滿足一定的條件,而不是匹配某些字符,因此,它們被成為 
零寬斷言

。所謂零寬,指的是它們不與任何字符相匹配,而匹配一個位置;所謂斷言,指的是一個判斷,正則表達式中只有當斷言為真時才會繼續進行匹配。零寬斷言可以精確的匹配一個位置,而不僅僅是簡單的指定句子或單字。

正規表示式把文字看作從左向右的字元流,向右叫做後向(Look behind),向左叫做前向(Look ahead)。對於正規表示式,只有當匹配到指定的模式(Pattern)時,斷言為True,叫做肯定式,把不匹配模式為True,叫做否定式。

依照符合的方向和配對的定性,把零寬斷言分成四種:

  • (?= pattern):前向、肯定断言
  • (?! pattern):前向、否定断言
  • (? pattern<code>):后向、肯定断言
  • (? pattern<code>):后向、否定断言

 1,前向肯定断言

前向肯定断言定义一个模式必须存在于文本的末尾(或右侧),但是该模式匹配的子串不会出现在匹配的结果中,前向断言通常出现在正则表达式的右侧,表示文本的右侧必须满足特定的模式:

 (?= subexpression )

使用前向肯定断言可以定一个模糊匹配,后缀必须包含特定的字符:

\b\w+(?=\sis\b)

对正则表达式进行分析:

  • \b:表示单词的边界
  •  \w+:表示单词至少出现一次
  • (?=\sis\b):前向肯定断言,\s 表示一个空白字符, is 是普通字符,完全匹配,\b 是单词的边界。

从分析中,可以得出,匹配该正则表达式的文本中必须包含 is 单词,is是一个单独的单词,不是某一个单词的一个部分。举个例子

Sunday is a weekend day 匹配该正则,匹配的值是Sunday,而The island has beautiful birds 不匹配该正则。

2,后向肯定断言

后向肯定断言定义一个模式必须存在于文本的开始(或左侧),但是该模式匹配的子串不会出现在匹配的结果中,后向断言通常出现在正则表达式的左侧,表示文本的左侧必须满足特定的模式:

(?<p>使用后向肯定断言可以定一个模糊匹配,前缀必须包含特定的字符:</p><pre class="brush:php;toolbar:false">(?<p>对正则表达式进行分析:</p>
  • (?:后向断言,\b表示单词的开始,20是普通字符
  • \d{2}:表示两个数字,数字不要求相同
  • \b:单词的边界

该正则表达式匹配的文本具备的模式是:文本以20开头、以两个数字结尾。

推荐学习:C#.Net教程

以上是C#之正規表示式介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:cnblogs。如有侵權,請聯絡admin@php.cn刪除
C#.NET與未來:適應新技術C#.NET與未來:適應新技術Apr 14, 2025 am 12:06 AM

C#和.NET通過不斷的更新和優化,適應了新興技術的需求。 1)C#9.0和.NET5引入了記錄類型和性能優化。 2).NETCore增強了雲原生和容器化支持。 3)ASP.NETCore與現代Web技術集成。 4)ML.NET支持機器學習和人工智能。 5)異步編程和最佳實踐提升了性能。

c#.net適合您嗎?評估其適用性c#.net適合您嗎?評估其適用性Apr 13, 2025 am 12:03 AM

c#.netissutableforenterprise-levelapplications withemofrosoftecosystemdueToItsStrongTyping,richlibraries,androbustperraries,androbustperformance.however,itmaynotbeidealfoross-platement forment forment forment forvepentment offependment dovelopment toveloperment toveloperment whenrawspeedsportor whenrawspeedseedpolitical politionalitable,

.NET中的C#代碼:探索編程過程.NET中的C#代碼:探索編程過程Apr 12, 2025 am 12:02 AM

C#在.NET中的編程過程包括以下步驟:1)編寫C#代碼,2)編譯為中間語言(IL),3)由.NET運行時(CLR)執行。 C#在.NET中的優勢在於其現代化語法、強大的類型系統和與.NET框架的緊密集成,適用於從桌面應用到Web服務的各種開發場景。

C#.NET:探索核心概念和編程基礎知識C#.NET:探索核心概念和編程基礎知識Apr 10, 2025 am 09:32 AM

C#是一種現代、面向對象的編程語言,由微軟開發並作為.NET框架的一部分。 1.C#支持面向對象編程(OOP),包括封裝、繼承和多態。 2.C#中的異步編程通過async和await關鍵字實現,提高應用的響應性。 3.使用LINQ可以簡潔地處理數據集合。 4.常見錯誤包括空引用異常和索引超出範圍異常,調試技巧包括使用調試器和異常處理。 5.性能優化包括使用StringBuilder和避免不必要的裝箱和拆箱。

測試C#.NET應用程序:單元,集成和端到端測試測試C#.NET應用程序:單元,集成和端到端測試Apr 09, 2025 am 12:04 AM

C#.NET應用的測試策略包括單元測試、集成測試和端到端測試。 1.單元測試確保代碼的最小單元獨立工作,使用MSTest、NUnit或xUnit框架。 2.集成測試驗證多個單元組合的功能,常用模擬數據和外部服務。 3.端到端測試模擬用戶完整操作流程,通常使用Selenium進行自動化測試。

高級C#.NET教程:ACE您的下一次高級開發人員面試高級C#.NET教程:ACE您的下一次高級開發人員面試Apr 08, 2025 am 12:06 AM

C#高級開發者面試需要掌握異步編程、LINQ、.NET框架內部工作原理等核心知識。 1.異步編程通過async和await簡化操作,提升應用響應性。 2.LINQ以SQL風格操作數據,需注意性能。 3..NET框架的CLR管理內存,垃圾回收需謹慎使用。

C#.NET面試問題和答案:提高您的專業知識C#.NET面試問題和答案:提高您的專業知識Apr 07, 2025 am 12:01 AM

C#.NET面試問題和答案包括基礎知識、核心概念和高級用法。 1)基礎知識:C#是微軟開發的面向對象語言,主要用於.NET框架。 2)核心概念:委託和事件允許動態綁定方法,LINQ提供強大查詢功能。 3)高級用法:異步編程提高響應性,表達式樹用於動態代碼構建。

使用C#.NET建築微服務:建築師實用指南使用C#.NET建築微服務:建築師實用指南Apr 06, 2025 am 12:08 AM

C#.NET是構建微服務的熱門選擇,因為其生態系統強大且支持豐富。 1)使用ASP.NETCore創建RESTfulAPI,處理訂單創建和查詢。 2)利用gRPC實現微服務間的高效通信,定義和實現訂單服務。 3)通過Docker容器化微服務,簡化部署和管理。

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
4 週前By尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
1 個月前By尊渡假赌尊渡假赌尊渡假赌

熱工具

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強大的PHP整合開發環境

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )專業的PHP整合開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)