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

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

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