Python map以及reduce函数

# -*- coding: utf-8 -*-
# 函数作为参数传入,这样的函数称为高阶函数,函数式编程就是指这种高度抽象的编程范式
from functools import reduce


def normalize(name):
   name = str.capitalize(name)
   return name


l1 = ['adam', 'LISA', 'barTa']
l2 = list(map(normalize, l1))  # map(函数,Iterable):将函数一次作用到每个元素,并将结果作为新的Iterator返回。
print(l2)


def prod(l):
   def fm(x, y):
      return x * y
   return reduce(fm, l)  # reduce(函数,序列):reduce必须接收两个参数,把结果继续和序列的下个元素累积计算。


print('3 * 5 * 7 * 9 =', prod([3, 5, 7, 9]))
if prod([3, 5, 7, 9]) == 945:
   print('测试成功!')
else:
   print('测试失败!')


def str2float(c):
   # 将字符转换成数字
   def str2num(c):
      return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[c]

   # 将获取到的数字列表进行排序
   def fa(a, b):
      return a*10 + b

   # 将获取到的数字列表进行小数点后排序
   def fb(a, b):
      return a/10 + b

   cindex = c.index('.')  # 获取小数点的索引位置

 # reduce(fa, map(str2num, c[:cindex])) + reduce(fa, map(str2num, c[(cindex+1):]))/10**len(c[(cindex+1):]))

   return reduce(fa, map(str2num, c[:cindex])) + reduce(fb, map(str2num, c[(cindex+1):][::-1]))/10


""""   
第一种计算方法不需要用到fb函数,reduce(fa, map(str2num, c[:cindex])),
首先map函数将原字符串小数点前的字符串通过str2num函数转换成相应的数字列表[1,3,5,6],
然后reduce函数通过fa函数将获取到的参数进行排序以此获得整数部分的数值例如1356.3645,
这个时候获取到的数值将为:1356,
map(str2num, c[(cindex+1):])从cindex+1位开始获取字符通过str2num将字符转化为数字列表[3,6,4,5],
通过reduce函数排序,获取到的数值为:3645
10**len(c[(cindex+1):])):**乘方运算,这里是通过获取字符串长度决定10的乘方数,将上面获取的3645/(10*10*10*10),
然后获得小数部分的数值:0.3645
最后将1356+0.3645的结果返回

第二种与第二种的区别在于小数部分的处理,第一种方法直接获取字符后组装成相应的数字通过除法,
将排序好的数字转成想要的小数部分的数值,第二种直接将获取到的字符转化成数字后/10变成小数然后排序.
但是如果直接[3,6,4,5] 通过fb函数排序的话那得到的结果将是:
0/10+3=3>>>3/10+3=6.3>>>6.3/10+4=4.63>>>4.63/10+5=5.463/10=0.5463,
所以在这里需要通过[::-1]进行倒序处理之后再排序转化成我们要的小数部分,具体如下:
map(str2num, c[(cindex+1):][::-1]))小数点的索引位+1开始获取字符串,
然后倒序传入str2num函数(例如1356.3645),这里经过倒序处理后将为:[5,4,6,3],
然后通过fb函数将获取的数字按照0/10+5>>>5/10+4=4.5>>>4.5/10+6=6.45>>>
6.45/10+3=3.645,最后再将3.645/10获得小数部分:0.3645
list[::-1]表示从最后一个索引位倒序获取字符组成一个list
list[4::1]从第4个索引位倒序获取字符,[1,3,4,52,32,11,1,1,]>>>[32,52,1,4,3,1]
最后将整数部+小数部分 1356+0.3645=1356.3645
"""

print('str2float(\'123.456\')=', str2float('123.456'))
if abs(str2float('123.456') - 123.456) < 0.00001:
   print('测试成功!')
else:
   print('测试失败!')
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章