[英]Split a unicode string into components containing numbers and letters
我想將字符串u'123K
為123
和K
我試過re.match("u'123K", "\\d+")
匹配數字,而re.match("u'123K", "K")
匹配字母,但是它們不起作用。 用Python的方式可以做到這一點?
使用re.findall()
查找所有數字和字符:
>>> s = u'123K'
>>> re.findall(r'\d+|[a-zA-Z]+', s) # or use r'\d+|\D+' as mentioned in comment in order to match all numbers and non-numbers.
['123', 'K']
如果您只處理此字符串,或者只想從最后一個字符中拆分字符串,則可以簡單地使用索引:
num, charracter = s[:-1], s[-1:]
您還可以使用itertools.groupby
方法對數字進行分組:
>>> import itertools as it
>>> for _,v in it.groupby(s, key=str.isdigit):
print(''.join(v))
123
K
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.