1. 程式人生 > >Python學習筆模式匹配與正則表達式之管理復雜的正則表達式

Python學習筆模式匹配與正則表達式之管理復雜的正則表達式

一點 根據 div lap 告訴 clas imp 示例 ()

隨筆記錄方便自己和同路人查閱。

#------------------------------------------------我是可恥的分割線-------------------------------------------

  如果要匹配的文本模式很簡單,正則表達式就很好。但匹配復雜的文本模式,可能需要長的、費解的正則表達式。

你可以告訴 re.compile(),忽略正則表達式字符串中的空白符和註釋,從而緩解這一點。要實現這種詳細模式,可以向

re.compile()傳入變量 re.VERBOSE,作為第二個參數。

#------------------------------------------------我是可恥的分割線-------------------------------------------

  示例代碼:

#! python 3
# -*- coding:utf-8 -*-
# Autor: Li Rong Yang
import re
#未使用re.VERBOSE方法
agentNamesRegex = re.compile(r‘((\d{3}|\(\d{3}\))?(\s|-|\.)?\d{3}(\s|-|\.)\d{4}(\s*(ext|x|ext.)\s*\d{2,5})?)‘)
#使用re.VERBOSE方法
phoneRegex = re.compile(r‘‘‘(
                        (\d{3}|\(\d{3}\))? # area code
                        (\s|-|\.)? # separator
                        \d{3} # first 3 digits
                        (\s|-|\.) # separator
                        \d{4} # last 4 digits
                        (\s*(ext|x|ext.)\s*\d{2,5})? # extension
                        )‘‘‘,re.VERBOSE)

  根據代碼可以看出,不使用re.VERBOSE時只能在一行中寫,但如果正則表達式太復雜,會影響閱讀。而使用re.VERBOSE則可以多行分開寫一行寫一種正則表達式。

Python學習筆模式匹配與正則表達式之管理復雜的正則表達式