functools.partial

来源:互联网 发布:excel表格重复的数据 编辑:程序博客网 时间:2024/06/10 19:49
函数式编程的思想。
可以理解成绑定了一部分参数的函数。
作用就是少传参数,更短,更简洁。
我之前做的一段用户留存率的程序。
需求是这样子的,选择某一天,然后以这天为准,次日留存,3日留存,7日留存,14日留存,30日留存。
已有一个获取第几天后的函数
源码打印?
  1. from datetime import datetime,timedelta  
  2. def GetNextDay(baseday,n):  
  3.     return str((datetime.strptime(str(baseday),'%Y-%m-%d')+timedelta(days=n)).date())  
>>GetNextDay('2013-07-31',2)
'2013-08-02'
按照常规做法,要获取这些“x日留存”的日期,需要
源码打印?
  1. GetNextDay(selected_day,1)  
  2. GetNextDay(selected_day,2)  
  3. GetNextDay(selected_day,6)  
  4. GetNextDay(selected_day,13)  
  5. GetNextDay(selected_day,29)  
可以看到,第一个参数都是一样的, 一些东西如果是一样的,往往意味着可以简化,就跟之前博文的itemgetter一样。
这时候偏函数派上用途了。
源码打印?
  1. import functools  
  2. nday = functools.partial(GetNextDay,selected_day)  
这样上面的的代码就可以简化成下面这样了。
源码打印?
  1. nday(1)  
  2. nday(2)  
  3. nday(6)  
  4. nday(13)  
  5. nday(29)  
原文链接:http://blog.csdn.net/handsomekang/article/details/9712125

原创粉丝点击