-
编写一个函数,交换指定字典的key和value。
#例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'} def change(dict1:dict): for x in dict1.keys(): dict1.setdefault(dict1.pop(x),x) return dict1 print(change({'a':1, 'b':2, 'c':3}))
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
# 例如: 传入'12a&bc12d-+' --> 'abcd' import re def merge_letter(str1:str): r = re.sub('[^a-zA-Z]','',str1) return r print(merge_letter("12a&bc12d-+"))
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
例如: 'abc' -> 'Abc' '12asd' --> '12asd' def my_capitalize(str1:str): if 'a'<= str1[0] <= 'z': str1 = chr(ord(str1[0]) - 32) + str1[1:] return str1 print(my_capitalize('abc'))
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
#例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True #字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False def my_endswith(str1:str,str2:str): l = len(str2) return str1[-l:] == str2 print(my_endswith('abcdab','ab'))
-
写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
#例如: '1234921' 结果: Truez #'23函数' 结果: False #'a2390' 结果: False def my_isdigit(str1:str): for x in str1: if not '0' <= x <= '9': return False else: return True print(my_isdigit('12356'))
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
#例如: 'abH23好rp1' 结果: 'ABH23好RP1' import re def trans(x): r = x.group() return chr(ord(r)-32) def my_upper(str1:str): r = re.sub('[a-z]',trans,str1) return r print(my_upper('abH23好rp1'))
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
# 例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc' # 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗' def my_rjust(str1:str,width:int,pad:str): l =len(str1) return pad * (width-l) + str1 print(my_rjust('abc',7,'^'))
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
#例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6 #列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4 # 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1 def my_index(str1:str,ele): if str1.count(ele) == 0: return -1 else: list1 = [] for i in range(len(str1)): if str1[i] == ele: list1.append(i) return list1 print(my_index([1, 2, 45, 'abc', 1, '你好', 1, 0],1))
-
写一个自己的len函数,统计指定序列中元素的个数
# 例如: 序列:[1, 3, 5, 6] 结果: 4 # 序列:(1, 34, 'a', 45, 'bbb') 结果: 5 # 序列:'hello w' 结果: 7 def my_len(sequence): count = 0 if type(sequence) == dict: for _ in sequence.values(): count += 1 else: for _ in sequence: count += 1 return count print(my_len('hello w'))
-
写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
#例如: 序列:[-7, -12, -1, -9] 结果: -1 # 序列:'abcdpzasdz' 结果: 'z' # 序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98 def my_max(sequence): if type(sequence) == dict: sequence = list(sequence.values()) maxNum = sequence[0] for x in sequence: if x > maxNum: maxNum = x return maxNum print(my_max({'小明':90, '张三': 76, '路飞':30, '小花': 98}))
-
写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
#例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False #序列: [12, 90, 'abc'] 元素: 90 结果: True def my_in(sequence,ele): if type(sequence) == dict: sequence = list(sequence.keys()) for x in sequence: if x == ele: return True else: return False print(my_in((12, 90, 'abc'),'90'))
-
写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
#例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: 'how are me? and me?' def my_replace(str1:str,str2:str,str3:str): l = len(str2) str4 = '' i = 0 while i <= len(str1)-l: if str1[i:i+l] == str2: str4 += str3 i += l else: str4 += str1[i] i += 1 return str4 + str1[i:] print(my_replace('how are you? and you?','you','me'))
day11-Python函数作业1
最新推荐文章于 2024-07-09 23:19:55 发布