-
利用列表推导式, 完成以下需求:
a. 生成一个存放1-100中各位数为3的数据列表:
list1 = [x for x in range(3,100,10)] print(list1) #结果为 [3, 13, 23, 33, 43, 53, 63, 73, 83, 93]
b. 利用列表推到是将 列表中的整数提取出来:
list1 = [True, 17, "hello", "bye", 98, 34, 21] list2 = [x for x in list1 if type(x) == int] print(list2) #例如:[True, 17, "hello", "bye", 98, 34, 21] --- [17, 98, 34, 21]
c. 利用列表推导式 存放指定列表中字符串的长度:
list1 = ["good", "nice", "see you", "bye"] list2 = [len(x) for x in list1] print(list2) #例如 ["good", "nice", "see you", "bye"] --- [4, 4, 7, 3]
d. dict_list = [{“科目”:“政治”, “成绩”:98}, {“科目”:“语文”, “成绩”:77}, {“科目”:“数学”, “成绩”:99}, {“科目”:“历史”, “成绩”:65}]
去除列表中成绩小于70的字典 【列表推导式完成】
dict_list = [{'科目':'政治', '成绩':98}, {'科目':'语', '成绩':77}, {'科目':'数学', '成绩':99}, {'科目':'历史', '成绩':65}] new_dict_list = [x for x in dict_list if x['成绩']>=70] print(new_dict_list) #结果为: [{“科目”:“政治”, “成绩”:98}, {“科目”:“语文”, “成绩”:77}, {“科目”:“数学”, “成绩”:99}]
-
编写函数,求1+2+3+…N的和
def sum1(N): s = 0 for a in range(1,N+1): s +=a print(s)
-
编写一个函数,求多个数中的最大值
def max1(*num1): max_num = num1[0] for x in num1: if x > max_num: max_num=x print(max_num)
-
编写一个函数,实现摇骰子的功能,打印N个骰子的点数和
import random def yao(N): s = 0 for a in range(N): s1 = random.randint(1, 6) s += s1 print(s)
-
编写一个函数,交换指定字典的key和value。
dic1 = {'a':1,'b':2,'c':3}
dic2 = {dic1[x]: x for x in dic1}
print(dic1)
#例如:dict1={'a':1, 'b':2, 'c':3} --> dict1={1:'a', 2:'b', 3:'c'}
-
编写一个函数,提取指定字符串中所有的字母,然后拼接在一起产生一个新的字符串
def joint(str1): str2 = '' for x in str1: if 'a' <= x <= 'z' or 'A'<= x <= 'Z': str2 +=x print(str2)
例如: 传入’12a&bc12d-+’ --> ‘abcd’
-
写一个函数,求多个数的平均值
def mean(*num1): if len(num1) == 0: print(0) else: print(sum(num1)/len(num1))
-
写一个函数,默认求10的阶乘,也可以求其他数字的阶乘
def factorial(a=10): s = 1 for a in range(1,a+1): s *= a print(s)
=======注意:以下方法不能使用系统提供的方法和函数,全部自己写逻辑
-
写一个自己的capitalize函数,能够将指定字符串的首字母变成大写字母
def new_capitalize(str1): str2 = '' if 'a' <= str1[0] <= 'z' : for x,y in enumerate(str1): if x == 0: str2 += chr(ord(y) - 32) else: str2 += y else: str2 += str1 print(str2) #例如: 'abc' -> 'Abc' '12asd' --> '12asd'
-
写一个自己的endswith函数,判断一个字符串是否已指定的字符串结束
def new_endswith(str1,str2): len1 = len(str1) len2 = len(str2) if str1[len1-len2:] == str2: print(True) else: print(False) #例如: 字符串1:'abc231ab' 字符串2:'ab' 函数结果为: True #字符串1:'abc231ab' 字符串2:'ab1' 函数结果为: False
-
写一个自己的isdigit函数,判断一个字符串是否是纯数字字符串
def new_isdigit(str1):
for num in str1:
if not('0' <= num <= '9'):
print(False)
break
else:
print(True)
# 例如: '1234921' 结果: True
# '23函数' 结果: False
# 'a2390' 结果: False
-
写一个自己的upper函数,将一个字符串中所有的小写字母变成大写字母
def new_upper(str1): str2 = '' for num in str1: if 'a'<= num <= 'z': str2 +=chr(ord(num)-32) else: str2 += num print(str2) #例如: 'abH23好rp1' 结果: 'ABH23好RP1'
-
写一个自己的rjust函数,创建一个字符串的长度是指定长度,原字符串在新字符串中右对齐,剩下的部分用指定的字符填充
def new_rjust(str1,num1,str2):
len1 = len(str1)
str3 = ''
for a in range(num1-len1):
str3 += str2
str3 += str1
print(str3)
#例如: 原字符:'abc' 宽度: 7 字符:'^' 结果: '^^^^abc'
# 原字符:'你好吗' 宽度: 5 字符:'0' 结果: '00你好吗'
-
写一个自己的index函数,统计指定列表中指定元素的所有下标,如果列表中没有指定元素返回-1
def new_index(list1,num1): count = 0 for a , b in enumerate(list1): if b == num1: print(a,end=',') count += 1 else: if count == 0: print(-1) #例如: 列表: [1, 2, 45, 'abc', 1, '你好', 1, 0] 元素: 1 结果: 0,4,6 # 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '赵云' 结果: 0,4 # 列表: ['赵云', '郭嘉', '诸葛亮', '曹操', '赵云', '孙权'] 元素: '关羽' 结果: -1
-
写一个自己的len函数,统计指定序列中元素的个数
def new_len(order1): count = 0 for b in order1: count += 1 print(count) #例如: 序列:[1, 3, 5, 6] 结果: 4 # 序列:(1, 34, 'a', 45, 'bbb') 结果: 5 # 序列:'hello w' 结果: 7
-
写一个自己的max函数,获取指定序列中元素的最大值。如果序列是字典,取字典值的最大值
def new_max(order1): if type(order1) == dict: order1 = list(order1.values()) else: order1 = list(order1) maxmast = order1[0] for x in order1[1:]: if x > maxmast: maxmast = x print(maxmast) #例如: 序列:[-7, -12, -1, -9] 结果: -1 # 序列:'abcdpzasdz' 结果: 'z' # 序列:{'小明':90, '张三': 76, '路飞':30, '小花': 98} 结果: 98
-
写一个函数实现自己in操作,判断指定序列中,指定的元素是否存在
def new_in(order1,num1): for a in order1: if a == num1: print(True) break else: print(False) #例如: 序列: (12, 90, 'abc') 元素: '90' 结果: False # 序列: [12, 90, 'abc'] 元素: 90 结果: True
-
写一个自己的replace函数,将指定字符串中指定的旧字符串转换成指定的新字符串
def new_replace(str1,str2,str3): str4 = '' list1 = [] + str1.split(str2) list2 = [] str4 = '' for x, y in enumerate(list1): list2.append(y) if x < len(list1)-1: list2.append(str3) print(list2) for x in list2: str4 += x print(str4) #例如: 原字符串: 'how are you? and you?' 旧字符串: 'you' 新字符串:'me' 结果: #'how are me? and me?'