繁体   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