1.*args和**kwargs用法:主要用于函数定义,*args相当于参数列表。如定义一个函数def test_var_args(f_arg,*argv),调用是test_var_args('yasoob','python','eggs','test'),则*argv='python','eggs','test';**kwargs允许传输不定长度的字典参数。函数调用顺序必须按照(a,*args,**kwargs);主要用于monkey patching和写函数装饰器时。
2.pdb库帮助代码进入debugging模式:1.命令行执行python -m pdb xxx.py;2.或在脚本里文件头添加import pdb,然后在需要单步调试的代码前添加pdb.set_trace();个人认为脚本添加pdb断点代码更好用。更多Pdb参考文档链接:https://docs.python.org/2/library/pdb.html 。
3.生成器(Generators):为一种只能迭代一次的迭代器,其所有的计算值都不存在内存中,而是一边计算一边生成值,并通过yield指令返回生成值。大多数的生成器都是通过函数实现,目前python3的标准函数库已经将返回对象更改成生成器,而python2则是返回列表。主要用于不想把一次性大量的计算结果存在内存当中的场景,以此来避免内存资源的大量消耗。而yield返回值需要next()来获取,当yield返回的值被用掉后next()会触发StopInteration异常。python里许多可迭代对象,包括str,但不意味着可以使用next()获取值,只有是迭代器才可以使用next()。
4.Map的使用:会将一个函数映射到一个列表里所有的元素上(可以是单个整数也可以是函数),且使用匿名函数lambda配合使用。如定义了item=[1,2,3,4,5],square=[],for i in items:square.append(i**2);可以写成square=list(map(lambda x:x**2,item))。
5.Filter的使用:用来选取列表里符合条件(自定义)的元素,且使用匿名函数lambda配合使用。如than_zero=list(filter(labmda x:x>0,numberList)),其中,numberList为待操作的列表。