作為一個概念而言,正則表達式對于Python來說并不是獨有的。但是,Python中的正則表達式在實際使用過程中還是有一些細小的差別。
將介紹Python中對字符串進行搜索和查找的一些方法,討論如何使用分組來處理我們查找到的匹配對象的子項。
使用的Python中正則表達式的模塊通常叫做‘re'。
>>> import re
1.Python中的原始類型字符串
Python編譯器用‘'(反斜杠)來表示字符串常量中的轉義字符。
如果反斜杠后面跟著一串編譯器能夠識別的特殊字符,那么整個轉義序列將被替換成對應的特殊字符(例如,‘/n'將被編譯器替換成換行符)。
但這給在Python中使用正則表達式帶來了一個問題,因為在‘re'模塊中也使用反斜杠來轉義正則表達式中的特殊字符(比如*和+)。
這兩種方式的混合意味著有時候你不得不轉義轉義字符本身(當特殊字符能同時被Python和正則表達式的編譯器識別的時候),但在其他時候你不必這么做(如果特殊字符只能被Python編譯器識別)。
與其將我們的心思放在去弄懂到底需要多少個反斜杠,我們可以使用原始字符串來替代。
原始類型字符串可以簡單的通過在普通字符串的雙引號前面加一個字符‘r'來創建。當一個字符串是原始類型時,Python編譯器不會對其嘗試做任何的替換。本質上來講,你在告訴編譯器完全不要去干涉你的字符串。
>>> string = 'This is a/nnormal string'>>> rawString = r'and this is a/nraw string'>>> print string
這是一個普通字符串
>>> print rawStringand this is a/nraw string
這是一個原始類型字符串。
在Python中使用正則表達式進行查找
‘re'模塊提供了幾個方法對輸入的字符串進行確切的查詢。我們將會要討論的方法有:
•re.match()
•re.search()
•re.findall()
每一個方法都接收一個正則表達式和一個待查找匹配的字符串。讓我們更詳細的查看這每一個方法從而弄明白他們是如何工作的以及他們各有什么不同。
2.使用re.match查找 主站蜘蛛池模板: 桑日县| 来安县| 福鼎市| 中卫市| 潮州市| 同江市| 乌兰察布市| 喀喇| 宜春市| 大同县| 独山县| 信宜市| 屏东市| 邓州市| 绵竹市| 吴堡县| 定兴县| 宜宾市| 电白县| 阿拉善盟| 新巴尔虎右旗| 内黄县| 奉新县| 轮台县| 涿州市| 古浪县| 九江市| 诸暨市| 堆龙德庆县| 东乌珠穆沁旗| 贵德县| 呼和浩特市| 尼玛县| 丰原市| 阳泉市| 聂拉木县| 颍上县| 新竹县| 张家口市| 永福县| 仁布县|