day11-函数作业

  1. 编写一个函数,交换指定字典的key和value。

    # 例如:dict1={'a':1, 'b':2, 'c':3}  -->  dict1={1:'a', 2:'b', 3:'c'}  
    
    # 法1:创建新的字典
    def change(dict1):
        new_dict = {
          
          }
        for key in dict1:
            value = dict1[key]
            # 交换键和值
            new_dict[value] = key
        print(new_dict)
    dict1={
          
          'a':1, 'b':2, 'c':3}
    change(dict1)  # {1: 'a', 2: 'b', 3: 'c'}
    
  2. 编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串

    # 例如: 传入'12a&bc12d-+'   -->  'abcd'  
    
    def letters(str1):
        new_str = ''
        for i in str1:
            if 'a' <= i <= 'z' or 'A' <= i <= 'Z':
                new_str += i
        print(f'字符串中所有的字母:{
            
            new_str}')
    
    str1 = '12a&bc12d-+'
    letters(str1)   # 字符串中所有的字母:abcd
    
  3. 写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母

    # 例如: 'abc' -> 'Abc'   '12asd'  --> '12asd'
    
    def capital(str1)->str:
        """将指定字符串的首字母变成大写字母"""
        new_str = ''
        if str1[0].islower():
            new_str = str1[0].upper() + str1[1:]
        else:
            new_str += str1
        print(f'字符串的首字母变成大写字母:{
            
            new_str}')
    
    str1 = 'abc'
    str2 = '12asd'
    capital(str1)    # 字符串的首字母变成大写字母:Abc
    capital(str2)    # 字符串的首字母变成大写字母:12asd
    
  4. 写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束

    #  例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True
    #        字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
    
    def endwith(str1, str2):
        """判断一个字符串是否已指定的字符串结束"""
        if str1[-len(str2):] == str2:
            print(True)
        else:
            print(False)
    
    str1 = 'abc123ab'
    str2 = 'ab'
    endwith(str1, str2)   # True
    
  5. 写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串

    #   例如: '1234921'  结果: True
    #         '23函数'   结果: False
    #         'a2390'    结果: False
    
    def digit(str1):
        for i in str1:
            if i.isdigit():
                continue
            else:
                print(False)
                break
        else:
            print(True)
    
    digit('123491')    # True
    digit('as123')    # False
    digit('12函数')    # False
    
  6. 写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母

    # 例如: 'abH23好rp1'   结果: 'ABH23好RP1'   
    
    def up(str1):
        new_str = ''
        for i in str1[:]:
            if 'a' <= i <= 'z':
                new_str += chr(ord(i) - 32)
            else:
                new_str += i
        print(new_str)
    
    up('abH23好rp1')    # ABH23好RP1
    
  7. 写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充

    # 例如: 原字符:'abc'  宽度: 7  字符:'^'    结果: '^^^^abc'
    #      原字符:'你好吗'  宽度: 5  字符:'0'    结果: '00你好吗'
    
    def rjust(str1, N, str2):
        new_str = str2*(N-len(str1)) + str1
        print(new_str)
        
    rjust('abc', 7, '^')    # ^^^^abc
    rjust('你好吗', 5, '0')    # 00你好吗
    
  8. 写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1

    # 例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0]  元素: 1   结果: 0,4,6  
    #      列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']  元素: '赵云'   结果: 0,4
    #      列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']  元素: '关羽'   结果: -1         
    
    def index(list1, item):
        index_list = []
        for i in range(len(list1)):
            if list1[i] == item:
                index_list.append(i)
        if index_list == []:
            print(-1)
        else:
            print(index_list)
    
    list2 = [1, 2, 45, 'abc', 1, '你好', 1, 0]
    index(list2, 1)    # [0, 4, 6]
    
    list3 = ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权']
    index(list3, '赵云')    # [0, 4]
    index(list3, '关羽')    # -1
    
  9. 写一个自己的len函数,统计指定序列中元素的个数

    # 例如: 序列:[1, 3, 5, 6]    结果: 4
    #       序列:(1, 34, 'a', 45, 'bbb')  结果: 5  
    #       序列:'hello w'    结果: 7
    
    def length(container):
        count = 0
        for i in container:
            count += 1
        print(f'序列的长度为:{
            
            count}')
        
    length([1, 3, 5, 6])    # 序列的长度为:4
    length((1, 34, 'a', 45, 'bbb'))    # 序列的长度为:5
    length('hello w')    # 序列的长度为:7
    
  10. 写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值

    # 例如: 序列:[-7, -12, -1, -9]    结果: -1   
    #      序列:'abcdpzasdz'    结果: 'z'  
    #      序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98}   结果:98
    
    def max_(container):
        if type(container) == dict:
            # 字典的话将value值先转换为列表
            container = list(container.values())
            
        container_max = container[0]
        for i in container[1:]:
            if i > container_max:
                container_max = i
        print(container_max)
    max_([-7, -12, -1, -9])    # -1
    max_('abcdpzasdz')    # z
    max_({
          
          '小明':90, '张三': 76, '路飞':30, '小花': 98})    # 98
    
  11. 写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在

    # 例如: 序列: (12, 90, 'abc')   元素: '90'     结果: False
    #      序列: [12, 90, 'abc']   元素: 90     结果: True   
    
    def in_(container, a):
        for i in container:
            if i == a:
                print(True)
                break
        else:
            print(False)
    
    in_((12, 90, 'abc'), '90')    # False
    in_([12, 90, 'abc'], 90)    # True
    
  12. 写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串

    # 例如: 原字符串: 'how are you? and you?'   旧字符串: 'you'  新字符串:'me'  结果: 'how are me? and me?'
    
    def replace(str1, old_str, new_str):
        new = new_str.join(str1.split(old_str))
        print(new)
    
    replace('how are you? and you?', 'you', 'me')    # how are me? and me?