簡體   English   中英

使用 Python 正則表達式中的排列捕獲重復子模式

[英]Capturing repeating sub-patterns with permutations in Python regex

我試圖標記一個由可以以任何順序出現的子模式組成的字符串。 子模式是下划線、字母或數字。 例如:

   'ABC_123_DEF_456' would provide ('ABC', '_', '123', '_', 'DEF', '_', '456')

這是實現的正則表達式給出了意想不到的結果:

>>> m = regex.match(r'^((_)|(\d+)|([[:alpha:]]+))+$', 'ABC_123_DEF_456')
>>> m.groups()
('456', '_', '456', 'DEF')

更新: - 排列:三個子模式可以以任何順序出現,例如:

'ABC123__' would provide ('ABC', '123', '_', '_')

您可以使用/([az]+|\\d+|_)/i將字符串分成數字組、字母組或單個下划線:

>>> re.findall(r"([a-z]+|\d+|_)", "ABC_123_DEF_456", re.I)
['ABC', '_', '123', '_', 'DEF', '_', '456']
>>> re.findall(r"([a-z]+|\d+|_)", "ABC123__", re.I)
['ABC', '123', '_', '_']

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM