Python functools模块学习总结

作者:junjie 时间:2023-09-22 07:21:54 

文档 地址

functools.partial

作用:

functools.partial 通过包装手法,允许我们 "重新定义" 函数签名

用一些默认参数包装一个可调用对象,返回结果是可调用对象,并且可以像原始对象一样对待

冻结部分函数位置函数或关键字参数,简化函数,更少更灵活的函数参数调用


#args/keywords 调用partial时参数
def partial(func, *args, **keywords):
    def newfunc(*fargs, **fkeywords):
        newkeywords = keywords.copy()
        newkeywords.update(fkeywords)
        return func(*(args + fargs), **newkeywords) #合并,调用原始函数,此时用了partial的参数
    newfunc.func = func
    newfunc.args = args
    newfunc.keywords = keywords
    return newfunc


声明:


urlunquote = functools.partial(urlunquote, encoding='latin1')


当调用 urlunquote(args, *kargs)

相当于 urlunquote(args, *kargs, encoding='latin1')

E.g:


import functools

def add(a, b):
    return a + b

add(4, 2)
6

plus3 = functools.partial(add, 3)
plus5 = functools.partial(add, 5)

plus3(4)
7
plus3(7)
10

plus5(10)
15

应用:

典型的,函数在执行时,要带上所有必要的参数进行调用。

然后,有时参数可以在函数被调用之前提前获知。

这种情况下,一个函数有一个或多个参数预先就能用上,以便函数能用更少的参数进行调用。

functool.update_wrapper

默认partial对象没有__name__和__doc__, 这种情况下,对于装饰器函数非常难以debug.使用update_wrapper(),从原始对象拷贝或加入现有partial对象

它可以把被封装函数的__name__、module、__doc__和 __dict__都复制到封装函数去(模块级别常量WRAPPER_ASSIGNMENTS, WRAPPER_UPDATES)


>>> functools.WRAPPER_ASSIGNMENTS
('__module__', '__name__', '__doc__')
>>> functools.WRAPPER_UPDATES
('__dict__',)


这个函数主要用在装饰器函数中,装饰器返回函数反射得到的是包装函数的函数定义而不是原始函数定义


#!/usr/bin/env python
# encoding: utf-8

def wrap(func):
    def call_it(*args, **kwargs):
        """wrap func: call_it"""
        print 'before call'
        return func(*args, **kwargs)
    return call_it

@wrap
def hello():
    """say hello"""
    print 'hello world'

from functools import update_wrapper
def wrap2(func):
    def call_it(*args, **kwargs):
        """wrap func: call_it2"""
        print 'before call'
        return func(*args, **kwargs)
    return update_wrapper(call_it, func)

@wrap2
def hello2():
    """test hello"""
    print 'hello world2'

if __name__ == '__main__':
    hello()
    print hello.__name__
    print hello.__doc__

    print
    hello2()
    print hello2.__name__
    print hello2.__doc__

得到结果:


before call
hello world
call_it
wrap func: call_it

before call
hello world2
hello2
test hello

functool.wraps

调用函数装饰器partial(update_wrapper, wrapped=wrapped, assigned=assigned, updated=updated)的简写


from functools import wraps
def wrap3(func):
    @wraps(func)
    def call_it(*args, **kwargs):
        """wrap func: call_it2"""
        print 'before call'
        return func(*args, **kwargs)
    return call_it

@wrap3
def hello3():
    """test hello 3"""
    print 'hello world3'

结果


before call
hello world3
hello3
test hello 3

functools.reduce


functools.reduce(function, iterable[, initializer])


等同于内置函数reduce()

用这个的原因是使代码更兼容(python3)

functools.cmp_to_key

functools.cmp_to_key(func)
将老式鼻尖函数转换成key函数,用在接受key函数的方法中(such as sorted(), min(), max(), heapq.nlargest(), heapq.nsmallest(), itertools.groupby())

一个比较函数,接收两个参数,小于,返回负数,等于,返回0,大于返回整数

key函数,接收一个参数,返回一个表明该参数在期望序列中的位置

例如:


sorted(iterable, key=cmp_to_key(locale.strcoll))  # locale-aware sort order

functools.total_ordering


functools.total_ordering(cls)


这个装饰器是在python2.7的时候加上的,它是针对某个类如果定义了__lt__、le、gt、__ge__这些方法中的至少一个,使用该装饰器,则会自动的把其他几个比较函数也实现在该类中


@total_ordering
class Student:
    def __eq__(self, other):
        return ((self.lastname.lower(), self.firstname.lower()) ==
                (other.lastname.lower(), other.firstname.lower()))
    def __lt__(self, other):
        return ((self.lastname.lower(), self.firstname.lower()) <
                (other.lastname.lower(), other.firstname.lower()))
print dir(Student)


得到


['__doc__', '__eq__', '__ge__', '__gt__', '__le__', '__lt__', '__module__']

标签:Python,functools,模块
0
投稿

猜你喜欢

  • Python字典的基础操作

    2023-02-27 06:25:18
  • OpenCV 表盘指针自动读数的示例代码

    2023-12-29 05:46:38
  • MySQL InnoDB ReplicaSet(副本集)简单介绍

    2024-01-20 11:10:45
  • MySQL学习之事务与并发控制

    2024-01-27 22:36:39
  • Python快速实现一个线程池的示例代码

    2021-06-01 04:51:01
  • ASP的URLDecode函数URLEncode解码函数

    2011-02-16 11:17:00
  • django框架中ajax的使用及避开CSRF 验证的方式详解

    2023-05-11 02:10:41
  • Echarts实例教程之树形图表的实现方法

    2024-04-18 09:44:01
  • python 安装教程之Pycharm安装及配置字体主题,换行,自动更新

    2021-01-02 06:34:20
  • python实现机械分词之逆向最大匹配算法代码示例

    2022-01-02 08:16:27
  • Python中的布尔类型bool

    2023-08-11 13:10:00
  • 浅谈python标准库--functools.partial

    2023-01-03 20:08:36
  • Python基于paramunittest模块实现excl参数化

    2023-12-27 00:29:02
  • python的set处理二维数组转一维数组的方法示例

    2022-03-30 12:37:02
  • Django之腾讯云短信的实现

    2021-05-15 04:30:54
  • 十几行的超简日历组件(兼容FF)js源码

    2010-08-08 08:49:00
  • Python eval函数原理及用法解析

    2021-04-29 05:17:18
  • Python中的面向对象编程详解(上)

    2021-10-12 14:33:45
  • Vue基础学习之项目整合及优化

    2024-05-21 10:28:49
  • 关于python3安装pip及requests库的导入问题

    2021-10-06 11:23:26
  • asp之家 网络编程 m.aspxhome.com