[英]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.