当前位置: 代码迷 >> 综合 >> map\reduce\sorted
  详细解决方案

map\reduce\sorted

热度:66   发布时间:2023-11-17 11:43:18.0
1、map
map()函数接收两个参数,一个是函数,一个是Iterable,map将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。
利用map()函数,把用户输入的不规范的英文名字,变为首字母大写,其他小写的规范名字。
输入:['adam', 'LISA', 'barT'],输出:['Adam', 'Lisa', 'Bart']:def fun(l):l_name=l[0].upper()+l[1:].lower()return l_name
l=['adam', 'LISA', 'barT']
print(list(map(fun,l)))list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
['1', '2', '3', '4', '5', '6', '7', '8', '9']2、reduce
用传给 reduce 中的函数 function(有两个参数)先对集合中的第
1、2 个元素进行操作,得到的结果再与第三个数据用 function 函数运算,最后得到一个结果。
from functools import reduce
def prod(x,y):return x * yL=[1,2,3,4,5]
print(reduce(prod, L))利用map和reduce编写一个str2float函数,把字符串'123.456'转换成浮点数123.456:def str2float(x):return float(x)
l=['12.369','145.021']
print(map(str2float,l))def str3float(x,y):return x+y
s='12.369'
print(reduce(str3float,s))coding=utf-8
def is_palindrome(n):s = str(n)l=int(len(n))s1=s[-1: :-1]i=0while i<l:if s[i]==s1[i]:print(s[i],s1[i])i=i+1else:return ('不是回数')return (s+'是回数')
x='989'
m=list(filter(is_palindrome,x))
print(str(m))3、sorted
sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower)#忽略大小写进行排序
['about', 'bob', 'Credit', 'Zoo']sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower, reverse=True)
['Zoo', 'Credit', 'bob', 'about']用sorted()对列表分别按名字排序
L = [('Bob', 75), ('Adam', 92), ('Bart', 66), ('Lisa', 88)]def fun(s):return s[0].lower()l=sorted(L,key=fun)#按照key来定义的排序方式key指定的函数作用于L每一个元素
print(l)
按成绩高低排序
L = [('Bob', 75), ('Adam', 92), ('Bart', 66), ('Lisa', 88)]
def fun(s):return s[1]
print(sorted(L,key=fun,reverse=True))4、lambdaL = list(filter(lambda n: n % 2 == 1, range(1, 20)))print(L)
  相关解决方案