Python函数的分阶段参数传递
最近用到个工程,因为考虑到效率,所以需要用Python中的filter()函数来过滤一个列表,而这个过滤函数实际上需要2个参数而filter()只能传递给过滤函数一个参数。仔细分析一下,这2个参数中,有1个参数是在request生存期内不变的,而另外一个是用于过滤的值。所以最终用了一下lambda来做了个函数的分阶段参数传递。例子如下:
过滤函数:
def myfilter(a,b):
"""b is a parameter that can't change at a request"""
if a%2==0:
return True
else:
return False
执行过程
fc=lambda a:myfilter(a,20)
filter(fc,[1,2,3,4,5,6,7,8])
这样,过滤函数 myfilter() 的两个参数是分开传递的。
Python是一种动态语言,而且还常常号称是动态语言里面最慢的一个。最近Ruby的出现才略微改变了一下这种情况,呵呵,听说Ruby比Python还要“动态”一些。在Python中提高效率的一种可选办法是确保可读性的情况下避免使用动态特性,比如过多的"."操作符就很低效。另外,就是可以用一些函数式编程的方法,比如很多内置函数,如map()、filter()、zip()等等,应用lambda也是个不错的办法。
最近用到个工程,因为考虑到效率,所以需要用Python中的filter()函数来过滤一个列表,而这个过滤函数实际上需要2个参数而filter()只能传递给过滤函数一个参数。仔细分析一下,这2个参数中,有1个参数是在request生存期内不变的,而另外一个是用于过滤的值。所以最终用了一下lambda来做了个函数的分阶段参数传递。例子如下:
过滤函数:
def myfilter(a,b):
"""b is a parameter that can't change at a request"""
if a%2==0:
return True
else:
return False
执行过程
fc=lambda a:myfilter(a,20)
filter(fc,[1,2,3,4,5,6,7,8])
这样,过滤函数 myfilter() 的两个参数是分开传递的。
Python是一种动态语言,而且还常常号称是动态语言里面最慢的一个。最近Ruby的出现才略微改变了一下这种情况,呵呵,听说Ruby比Python还要“动态”一些。在Python中提高效率的一种可选办法是确保可读性的情况下避免使用动态特性,比如过多的"."操作符就很低效。另外,就是可以用一些函数式编程的方法,比如很多内置函数,如map()、filter()、zip()等等,应用lambda也是个不错的办法。