# -*- coding: utf-8 -*-
from functools import reduce
def str2float(s):
def fn(x, y):
return x * 10 + y
def char2num(s):
return {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}[s]
# 得到字符串中.的索引
n = s.index('.')
# 根据.的位置将字符串切片为两段
s1 = list(map(int, [x for x in s[: n]]))
s2 = list(map(int, [x for x in s[n + 1 :]]))
# m ** n表示m的n次方
return reduce(fn, s1) + reduce(fn, s2) / 10 ** len(s2)
# 测试结果是否正确
print('str2float(\'123.456\')=',str2float('123.456'))
答案非原创,只是对别人的答案进行了完善和总结。
总结:
map()
函数接收两个参数,一个是函数,一个是Iterable
,map
将传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator
返回。比如map(int, ['1', '2', '3']) 就是把字符1、2、3都转换为int类型。
reduce
把一个函数作用在一个序列[x1, x2, x3, ...]
上,这个函数必须接收两个参数,reduce
把结果继续和序列的下一个元素做累积计算,就像这样:
reduce(f, [x1, x2, x3, x4]) = f(f(f(x1, x2), x3), x4)