接上一篇,
1,高阶函数:一个函数接收另一个函数作为参数
def add(x, y, f):
return f(x) + f(y)
add(-5, 6, abs)
11
2,map() 函数接收两个参数,一个是函数,一个是Iterable,传入的函数依次作用到序列的每个元素,并把结果作为新的Iterator返回。
def f(x):
return x * x
#把f(x)作用在list的每一个元素并把结果生成一个新的list
r = map(f, [1, 2, 3, 4, 5, 6, 7, 8, 9])
list(r)
[1, 4, 9, 16, 25, 36, 49, 64, 81]
list(map(str, [1, 2, 3, 4, 5, 6, 7, 8, 9]))
['1', '2', '3', '4', '5', '6', '7', '8', '9']
3,reduce() 把一个函数作用在一个序列上,这个函数必须接收两个参数,reduce把结果继续和序列的下一个元素做累积计算
from functools import reduce
def add(x, y):
return x + y
reduce(add, [1, 3, 5, 7, 9])
25
#字符串变化成整数
DIGITS = {'0': 0, '1': 1, '2': 2, '3': 3, '4': 4, '5': 5, '6': 6, '7': 7, '8': 8, '9': 9}
def char2num(s):
return DIGITS[s]
def str2int(s):
return reduce(lambda x, y: x * 10 + y, map(char2num, s))
# reduce和map联合
4,Python内建的filter()函数用于过滤序列,Python内建的filter()函数用于过滤序列
把一个序列中的空字符串删掉,可以这么写
def not_empty(s):
return s and s.strip()
list(filter(not_empty, ['A', '', 'B', None, 'C', ' ']))
# 结果: ['A', 'B', 'C']
5,Python内置的sorted()函数就可以对list进行排序
>>> sorted(['bob', 'about', 'Zoo', 'Credit'], key=str.lower, reverse=True)
['Zoo', 'Credit', 'bob', 'about']
6,闭包,引用循环变量时,再创建一个函数,用该函数的参数绑定循环变量当前的值,无论该循环变量后续如何更改,已绑定到函数参数的值不变:
def count():
fs = []
for i in range(1, 4):
def f():
return i*i
fs.append(f)
return fs
f1, f2, f3 = count()#结果全为9
解决办法
def count():
def f(j):
def g():
return j*j
return g
fs = []
for i in range(1, 4):
fs.append(f(i)) # f(i)立刻被执行,因此i的当前值被传入f()
return fs
>>> f1, f2, f3 = count()#否则结果全是9
>>> f1()
1
>>> f2()
4
>>> f3()
9
7,装饰器(Decorator)
def now():
print('2015-3-25')
def log(func):
def wrapper(*args, **kw):
print('call %s():' % func.__name__)
return func(*args, **kw)
return wrapper
@log
def now():
print('2015-3-25')
>>> now()
call now():
2015-3-25
把@log放到now()函数的定义处,相当于执行了语句:now = log(now)。
8,偏函数
import functools
>>> int2 = functools.partial(int, base=2)#int中有base参数,转化成二进制
>>> int2('1000000')
64
>>> int2('1010101')
85
9,每一个包目录下面都会有一个__init__.py的文件,这个文件是必须存在的,否则,Python就把这个目录当成普通目录,而不是一个包。init.py可以是空文件,也可以有Python代码,因为__init__.py本身就是一个模块,而它的模块名就是mycompany。
未指定具体的模块,就使用默认的__init__.py,否则必须指定到具体的模块
mycompany
├─ __init__.py
├─ abc.py
└─ xyz.py
10,类似__xxx__这样的变量是特殊变量,可以被直接引用,但是有特殊用途,比如__author__,name;
类似_xxx和__xxx这样的函数或变量就是非公开的(private),不应该被直接引用,比如_abc,abc等;
11,Python解释器把一个特殊变量__name__置为__main,而如果在其他地方导入该模块时,if判断将失败,因此,这种if测试可以让一个模块通过命令行运行时执行一些额外的代码,最常见的就是运行测试。
if __name__=='__main__':
test()