python基础之实现split函数

思路就是先找到分割的位置,那么就需要前面的split函数,接着分割即可
def my_find(source,target,start=0):
    if not source or not target:
        return -1
    if len(target) > len(source):
        return -1
    if start < 0 or start >= len(source):
        return -1
    
    for index in range(start,len(source)-len(target)+1):
        t_index = 0
        while t_index < len(target):
            if target[t_index] == source[t_index+index]:
                t_index += 1
            else:
                break
        
        if t_index == len(target):
            return index 
        
    return -1

def my_split(source,sep,maxsplit=-1):
    if not source or not sep:
        return []
    lst = []
    max_split_count = maxsplit if maxsplit >0 else len(source)#用于定义分几次
    split_count = 0
    
    start_index = 0#开始的位置
    index = my_find(source,sep,start = start_index)#找到第一次的分界点
    while split_count < max_split_count and index != -1:#用于判断是否找完了
        sep_str = source[start_index:index]#截取第一次的长度,就是第一次分界的长度
        lst.append(sep_str)#加入列表
        split_count += 1#+1
        start_index = index + len(sep)#第二次分界开始的地方
        index = my_find(source,sep,start=start_index)#从第二次分界的地方往后寻找新的分界点,以此循环
        
    sep_str = source[start_index:]#截取最后一个分界点后面的所有内容
    lst.append(sep_str)#加入列表
    
    return lst

if __name__ == "__main__":
    print(my_split("1,3,4",","))
    print(my_split("1,,3,,4",",,"))
    print(my_split("abcadae","a"))
    print(my_split("abcadae","a",maxsplit=2))
    print(my_split("aaaa","a"))
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值