欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

封装系统内置功能的函数(字符串)

程序员文章站 2022-04-15 15:57:07
1、封装类似lower()的函数 2、封装类似upper()的函数 3、封装类似find()的函数 4、封装类似rfind()的函数 5、封装功能类似isdigit()的函数 6、封装功能类似partition()的函数 ......

1、封装类似lower()的函数

def mylower(src):
    src1 = ''
    for i in src:
        if 'a' <= i <= 'z':
            src1 += chr(ord(i) + 32)
        else:
            src1 += i
    return src1
#print(mylower('acdejlg'))

 2、封装类似upper()的函数

def myupper(src):
    src1 = ''
    for i in src:
        if 'a' <= i <= 'z':
            src1 += chr(ord(i) - 32)
        else:
            src1 += i
    return src1
#print(myupper('acdef'))


 3、封装类似find()的函数

第一种思路:
def myfind1(src,sub):
    for i in range(len(src)-len(sub)+1):
        new_src = src[i:i+len(sub)]
        #print(new_src)
        if new_src == sub:
            return i
    else:
        return -1
print(myfind1('abcde123abe','123a'))
第二种思路:
def myfind(src,sub):

    if len(sub) > len(src):
        return -1
    for i in range(len(src)):
        if src[i] == sub[0]:
            index = i
            for j in range(len(sub)):
                if src[index] != sub[j]:
                    break
                index += 1
            else:
                return i
    else:
        return -1

 4、封装类似rfind()的函数

第一种思路:
def myrfind(src,sub):
    #从右往左进行遍历
    for i in range(len(src)-1,-1,-1):
        #先找第一个字符,如果一致,在进行对应切片比较
        if sub[0] == src[i]:
            #如果切片出来的结果与子串一致,返回所在的索引值
            if sub == src[i:i+len(sub)]:
                return i
    #如果没找到,返回-1
    else:
        return -1
# index = myrfind('abc123','c1')
# print(index)

第二种思路:
def myrfind(src,sub):
    if len(sub) > len(src):
        return -1
    for i in range(-1,-len(src)-1,-1):
        if src[i] == sub[0]:
            index = i
            for j in range(len(sub)):
                if src[index] != sub[j]:
                    break
                index += 1
            else:
                return len(src) + i
    else:
        return -1
#print(myrfind('abcdegabeda','ab'))

 5、封装功能类似isdigit()的函数

def myisdigit(src):
    for ch in src:
        if not '0' <= ch <= '9':
            return false
    else:
        return true
print(myisdigit('123'))
print(myisdigit('123a'))

 6、封装功能类似partition()的函数

def mypartition(src,sub):
    if sub in src:
        #获取子串在目标字符串的索引值
        index = myrfind(src,sub)
        #切片操作划分三个元素:  1.str[0:index]  2.sub 3.[index+len(sub):]
        return (src[0:index],sub,src[index+len(sub):])
    else:
        return (src,'','')
# print(mypartition('abcdef','g'))
print(mypartition('abcdef','cd'))