我不能用我擁有的正則表達(dá)式得到我想要的東西,例如一個字符串2000H2HfH我需要得到['2000','H','2','Hf','H']。所以,我需要按數(shù)字和大寫字母或大寫字符串拆分我使用它([A-Z][a-z]?)(\d+)?并丟失了凝視數(shù)字,這是可以理解的原因,但我無法取回它以使結(jié)果可讀?
2 回答

達(dá)令說
TA貢獻(xiàn)1821條經(jīng)驗(yàn) 獲得超6個贊
你可以使用
re.findall(r'\d+|[A-Z][a-z]*',?text)
細(xì)節(jié):
\d+
- 1+ 位數(shù)|
- 或者[A-Z][a-z]*
- 一個大寫字母,然后是零個或多個小寫字母。
import re
text = "2000H2HfH"
print( re.findall(r'\d+|[A-Z][a-z]*', text) )
# => ['2000', 'H', '2', 'Hf', 'H']

四季花海
TA貢獻(xiàn)1811條經(jīng)驗(yàn) 獲得超5個贊
你有兩個一個接一個的捕獲組,所以你一個接一個地捕獲它們。為了實(shí)現(xiàn)你的目標(biāo),你應(yīng)該像這樣修改你的捕獲
([A-Z][a-z]?|\d+)?
這里的 |?符號表示您捕獲大寫字母后跟小寫字母或數(shù)字。
添加回答
舉報(bào)
0/150
提交
取消