问题
我们要把某个字符串依据分割符号拆分不通的字段,该字符串包含多种不通的分隔符,例如:
s = 'ab;cd|gajfdak|gakjf,fah'
如何处理?
解决方案
- 连续使用str.split()方法
- 使用正则表达式的re.split(),一次性拆分字符串。
# -*- coding: utf-8 -*-
def mySplit(s, ds):
res = [s]
for d in ds:
t = []
map(lambda x: t.extend(x.split(d)), res)
res = t
return res
if __name__ == "__main__":
s = 'ab;cd|efg|hi,jkl|mn\topq;rst,uvw\txyz'
print mySplit(s, ';,|\t')
其输出结果为:
['ab', 'cd', 'efg', 'hi', 'jkl', 'mn', 'opq', 'rst', 'uvw', 'xyz']
虽然,我们将分隔符号给处理掉了, 但如果有两个连续的分隔符号,这种方法就会出现异常,如:s=’ab;cd|efg|hi,,;jkl|mn\topq;rst,uvw\txyz’,其运行结果如下:
['ab', 'cd', 'efg', 'hi', '', '', 'jkl', 'mn', 'opq', 'rst', 'uvw', 'xyz']
我们会发现结果列表中多出两个空字符。假设我们需要不含空字符的结果列表,那么我们又要对结果列表中的空字符进行处理,其代码如下:
def mySplit(s, ds):
res = [s]
for d in ds:
t = []
map(lambda x: t.extend(x.split(d)), res)
res = t
return [x for x in res if x]
其输出结果为:
['ab', 'cd', 'efg', 'hi', 'jkl', 'mn', 'opq', 'rst', 'uvw', 'xyz']
因此, 我们这里推荐采用方法二对分隔符进行处理,其代码如下:
# -*- coding: utf-8 -*-
import re
s = 'ab;cd|efg|hi,,;jkl|mn\topq;rst,uvw\txyz'
print re.split(r'[,;\t|]+', s)
其输出结果为:
['ab', 'cd', 'efg', 'hi', 'jkl', 'mn', 'opq', 'rst', 'uvw', 'xyz']
当我们处理单个分隔符时,推荐使用str.split();当我们对多个分隔符进行处理时,推荐使用re.split()。