Python 过滤字母和数字

如果想从一个含有数字,汉字,字母的列表中滤除仅含有数字的字符,当然可以采取正则表达式来完成,但是有点太麻烦了,因此可以采用一个比较巧妙的方式:

1、 正则表达式解决

import re
L = [u'小明', 'xiaohong', '12', 'adf12', '14']
for i in range(len(L)):
    if re.findall(r'^[^\d]\w+',L[i]):
        print re.findall(r'^\w+$',L[i])[0]
    elif isinstance(L[i],unicode):
        print L[i]

2、 巧妙地避开正则表达式

L = [ 'xiaohong', '12', 'adf12', '14',u'晓明']
for x in L:
    try:
        int(x)
    except:
        print x

3、 使用string内置方法

L = [ 'xiaohong', '12', 'adf12', '14',u'晓明']
#对于python3来说同样还可以使用string.isnumeric()方法
for x in L:
    if not x.isdigit():
        print x

4、 去除两端的数字

如果只是去除两端可能含有数字的字符串里的数字,则可以使用内置的strip,方式如下:

import string
astring = '12313213215just for 32 test 1306436'
print astring.strip(string.digits)  # 'just for 32 test '
print astring.rstrip(string.digits)  # '12313213215just for 32 test '
print astring.lstrip(string.digits)  # 'just for 32 test 1306436'

.strip([char]) 中的 char给定时,则截取两端的字符直到满足不在set(char) 中,不需要有序,切记!

import string
astring = '12313213215just for 32 test 1306436'
print astring.strip('0123456') # 'just for 32 test '

以下分别是python2和python3中string的方法:

这里写图片描述

转载自链接

猜你喜欢

转载自blog.csdn.net/wumian0123/article/details/81434906