这里比较的高级了, 学到这里感觉有点意思,但是也看到了和其他语言相通点
高阶函数 可以把别的函数作为参数传入的函数叫高阶函数
def add(x, y, f):
return f(x) + f(y)
add(-5, 6, abs) # 11
# 匿名函数 python使用lambda来创建匿名函数
sum = lambda arg1, arg2 : arg1 + arg2
sum(10, 20) # 30
# reduce 内建函数是个二元操作函数, 用来将一个数据集合所有数据进行二元操作
# 先对集合第1,2 个数据进行func()操作,得到的结果与第三个数据用func()运行,如此最后得到一个结果
# 顾名思义就是reduce将一个list缩成一个值
from functools import reduce
l = [1,2,3,4,5]
print(reduce(lambda x, y: x-y , 1))
# x 开始的时候赋值为10, 然后依次
print(reduce(lambda x, y: x-y, l, 10))
# map 应用于每一个可迭代的项返回一个结果list,map函数会把每一个参数都以相应的处理函数进行迭代处理
# 本质就是将原有的list根据lambda法则变成另一个list
l = [1, 2, 3]
new_list = list(map(lambda i: i+1, l))
# 变成了 [2, 3, 4]
l2 = [4, 5, 6]
new_list = list(map(lambda x, y : x + y, l, l2))
# 变成了 [5, 7, 9]
# filter 对序列进行过滤处理
l = [100, 20, 24, 50, 110]
new = list(filter(lambda x : x < 50 , l))
# [20, 24]
# 装饰器 和测试方法中的@before @test @end 类似 可以带参 和 多个装饰器
# 简单来说,你处理一个方法时需要统一做某件事
from functools import wraps
def makeHtmlTag(tag, *args, **kwds):
def real_decorator(fn): # fn is hello()
css_class = " class='{0}'".format(kwds["css_class"]) \
if "css_class" in kwds else ""
def wrapped(*args, **kwds):
return "<" + tag + css_class + ">" + fn(*args, **kwds) + "</"+tag+">"
return wrapped
return real_decorator
@makeHtmlTag(tag="b", css_class="bold_css")
@makeHtmlTag(tag="i", css_class="italic_css")
def hello():
return "hello world"
print(hello())
# <b class='bold_css'><i class='italic_css'>Hello World</i></h>
# 这里包了俩层 b为最外面的那层,i为中间层
# 高效率的递归 这里有个问题就是输入60会超过整数范围从而报错
from functools import wraps
from datetime import datetime
def memo(fn):
cache= {}
miss= object()
@wraps(fn)
def wrapper(*args):
result = cache.get(args, miss)
if result is miss:
result = fn(*args)
cache[args] = result
return result
return wrapper
@memo
def fib(n):
if n<2:
return n
return fib(n-1) + fib(n-2)
start = datetime.now()
print(fib(40)) # 102334155
end = datetime.now()
print((end - start).microseconds) # 71061
def fib2(n):
if n<2:
return n
return fib2(n-1) + fib2(n-2)
start1 = datetime.now()
print(fib2(40)) # 102334155
end1 = datetime.now()
print((end1 - start1).microseconds) # 641741
# 偏函数 只设置一部分参数
int('123455') # 默认转化为10进制
int('123456', base 8) # 8进制
int('123456', base 16) # 16进制
# 为了方便不需要每次都输入多少进制的值
def int2(x, base=2):
return int(x, base)
# 借助functools.partial来创建一个偏函数
import functools
int2 = functools.partial(int, base=2)
print(int2('1000000'))
# 传字典可以默认参数
kw = {'base': 2}
print(int('10010', **kw))
# 传list
args = (10, 5, 6, 7)
print(max(*args))
I'm fish, I'm on.