簡體   English   中英

將unicode字符串拆分為包含數字和字母的組件

[英]Split a unicode string into components containing numbers and letters

我想將字符串u'123K123K 我試過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.

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