在Python中,使用正則表達式處理復雜模式需要掌握一些基本概念和技巧。以下是一些建議和步驟,幫助你處理復雜模式:
import re
pattern = r'^(?=.*[A-Za-z])(?=.*\d)(?=.*[@$!%*#?&])[A-Za-z\d@$!%*#?&]{8,}$'
search()
、findall()
、match()
、sub()
等。根據你的需求選擇合適的函數。search()
:在字符串中查找第一個與模式匹配的子串。result = re.search(pattern, "example@1234")
if result:
print("Match found:", result.group())
else:
print("No match found")
findall()
:在字符串中查找所有與模式匹配的子串,并返回一個列表。results = re.findall(pattern, "example1@1234, example2@4567")
print("Matches found:", results)
match()
:從字符串的開頭開始匹配,如果開頭與模式不匹配,則返回None。result = re.match(pattern, "example@1234")
if result:
print("Match found:", result.group())
else:
print("No match found")
sub()
:將字符串中與模式匹配的所有子串替換為指定的字符串。new_string = re.sub(pattern, "replaced", "example@1234, example2@4567")
print("Replaced string:", new_string)
re.search()
或re.findall()
的返回值訪問。反向引用(\1
、\2
等)允許你在替換字符串中使用捕獲組的內容。例如,匹配包含兩個數字的字符串,并將它們替換為它們的和:
pattern = r'(\d+)\D+(\d+)'
text = "abc12 def34"
result = re.sub(pattern, lambda match: str(int(match.group(1)) + int(match.group(2))), text)
print("Replaced string:", result)
(?=...)
)允許你檢查字符串中的未來字符,而后顧斷言((?<=...)
)允許你檢查字符串中的過去字符。這對于更復雜的匹配模式非常有用。例如,匹配緊跟在"$"符號后面的數字:
pattern = r'\$(\d+)'
text = "Price: $100"
result = re.search(pattern, text)
if result:
print("Match found:", result.group(1))
else:
print("No match found")
通過掌握這些基本概念和技巧,你應該能夠處理Python中的復雜正則表達式模式。