首页 > 其他 > 详细

split函数的实现

时间:2014-06-20 21:30:16      阅读:350      评论:0      收藏:0      [点我收藏+]
split函数的功能是按照,一个指定的分隔符seperator,对字符串进行分割,形成很多子串。这是一个很常用的函数,每种语言的字符串相关的库函数中都有这个函数的实现。下面是我自己通过对split函数的理解,总结出的该函数的实现步骤:
s="   ...faffaffj  wejl;ajf;l end jfjj  "
1、利用find函数,找到第一个分隔符所在的位置,如果find返回-1,打印整个字符串s
2、否则,寻找第一分隔符以后第一个不为分隔符的字符的位置p,打印从字符串的开始到p之间的子串
3 从p开始寻找下一个分隔符q,p q之间就是一个分割
4、重复上面的动作3
下面是用python写的代码:
def simu_split(sep):
    s1="www  neu   edu    cn"
    #s1=s1.strip()
    length=len(s1)
    print length
    a=s1.find(sep)
    n=len(sep)
    if a==-1:
        print s1
    elif:
        print s1[:a],
    while a<length and a!=-1:
        
        while a<length and s1[a:a+n]==sep ://这一步跟标准库的处理不同,标准库是遇到一个
                                                            //sep就打印
            a+=n
        b=a
        a=s1.find(sep,b)
        if a==-1:
            print s1[b:length],
        else:
            print s1[b:a],
    else:
        print "\nelse"
    print "out of while"
simu_split(" ")
print "end of the file"
上面是我自己的实现,下面的是标准库的实现。我自己实现的版本与标准库的实现版本的区别是:两个seperator相连时,标准库的是把两个seperator之间当作存在空格,输出;我的版本是跳过不进行输出。下面的是标准库的实现的python代码:
def simu_split(sep):
    s1="www  neu   edu    cn"
    #s1=s1.strip()
    length=len(s1)
    print length
    a=s1.find(sep)
    n=len(sep)
    if a==-1:
        print s1
    elif:
        print s1[:a],
    while a<length and a!=-1:
        
        #while a<length and s1[a:a+n]==sep :
           # a+=n
        b=a
        a=s1.find(sep,b)
        if a==-1:
            print s1[b:length],
         elif (b-a)==n:
               print "   "
        else:
            print s1[b:a],
    else:
        print "\nelse"
    print "out of while"
simu_split(" ")
print "end of the file"

 

split函数的实现,布布扣,bubuko.com

split函数的实现

原文:http://www.cnblogs.com/wangyichao/p/3796014.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!