如何拆分含有多种分隔符的字符串

问题
我们要把某个字符串依据分割符号拆分不通的字段,该字符串包含多种不通的分隔符,例如:
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()。

你可能感兴趣的:(如何拆分含有多种分隔符的字符串)