>  기사  >  백엔드 개발  >  Python의 functools 모듈 기능 분석 정보

Python의 functools 모듈 기능 분석 정보

高洛峰
高洛峰원래의
2017-03-13 09:15:301744검색

이 글은 주로 Python의 functools 모듈 함수 분석에 대해 소개하고, functools.cmp_to_key와 functools에 대해 각각 설명합니다. .total_ordering, functools.reduce, functools.partial, functools.update_wrapper 및 functools.wraps 사용법, 도움이 필요한 친구는

Python을 참고하세요. 내장 functools 모듈은 다른 기능을 처리하는 데 사용되는 특수 기능인 일반적으로 사용되는 일부 고차 기능을 제공합니다. 즉, 이 모듈을 사용하여 호출 가능한 객체 를 처리할 수 있습니다.

functools 모듈 기능개요

  • functools.cmp_to_key(func)

  • functools.total_ordering(cls)

  • functools.reduce(function, iterable[, 초기화])

  • functools.partial (func[, args][, *키워드])

  • functools.update_wrapper(래퍼, 래핑[, 할당됨][, 업데이트됨])

  • functools.wraps(래핑됨[, 할당됨][, 업데이트됨])

functools.cmp_to_key()

구문:

functools.cmp_to_key(func) 

이 함수는 기존 비교 함수를 키워드 함수로 변환하는 데 사용됩니다.

기존 비교 함수: 두 개의 매개변수를 입력받아 비교 결과를 반환합니다. 반환값이 0보다 작으면 전자가 후자보다 작고, 반환값이 0보다 크면 그 반대이고, 반환값이 0이면 둘은 같다.

키워드 함수: 매개변수를 수신하고 해당 비교 객체를 반환합니다. 예를 들어 sorted(), min(), max(), heapq.nlargest(), heapq.nsmallest(), itertools.groupby()는 모두 다음과 같을 수 있습니다. 키워드 기능으로 사용됩니다.

Python 3에서는 이전 비교 함수를 더 이상 지원하지 않는 곳이 많습니다. 이때 cmp_to_key()를 사용하여 변환할 수 있습니다.

예:


sorted(iterable, key=cmp_to_key(cmp_func))

functools.total_ordering()

구문:

functools.total_ordering(cls) 

클래스의 비교 연산을 자동으로 구현하는 데 사용되는 클래스 데코레이터입니다.

클래스에서 eq() 메소드와 lt(), le(), gt(), ge() 메소드 중 하나를 구현하기만 하면 total_ordering()이 자동으로 도움이 될 수 있습니다. 그것을 구현하십시오. 나머지 비교 작업.

예:


@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()))

functools.reduce()

구문:

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

이 함수는 Python에 내장된 Reduce() 함수와 동일하며 주로 Python 3에 호환되는 코드를 작성하는 데 사용됩니다.

functools.partial()

구문:

functools.partial(func[, *args][, **keywords]) 

함수는 부분 객체인 경우, 이 객체를 호출하는 효과는 func 함수를 호출하고 위치 매개변수 args 및 키워드 매개변수 키워드를 전달하는 것과 동일합니다. 위치 인수를 사용하여 객체를 호출하면 이러한 인수가 args에 추가됩니다. 키워드 인수가 전달되면 키워드에 추가됩니다.

partial() 함수의 동등한 구현은 대략 다음과 같습니다.


def partial(func, *args, **keywords): 
  def newfunc(*fargs, **fkeywords):
    newkeywords = keywords.copy()
    newkeywords.update(fkeywords)
    return func(*(args + fargs), **newkeywords)
  newfunc.func = func
  newfunc.args = args
  newfunc.keywords = keywords
  return newfunc

partial() 함수는 주로 일부 매개변수를 "고정"하는 데 사용됩니다. 함수. 더 적은 수의 매개변수와 더 간단한 사용법을 가진 함수 객체를 반환합니다.

예:


>>> from functools import partial
>>> basetwo = partial(int, base=2)
>>> basetwo.doc = &#39;Convert base 2 string to an int.&#39;
>>> basetwo(&#39;10010&#39;)
18

functools.update_wrapper()

구문:

functools.update_wrapper(wrapper, 감싸인[, 할당된][, 업데이트된])

이 함수는 래퍼 함수(래퍼)를 다음과 같이 업데이트하는 데 사용됩니다. 원래 기능은 동일합니다. 선택적 매개변수는 튜플이고, 할당된 튜플은 속성 을 원래 함수의 값으로 직접 대체하도록 지정하고, 업데이트된 튜플은 원래 함수에 대해 업데이트할 속성을 지정합니다. 이 두 매개변수의 기본값은 각각 모듈 수준 상수인 WRAPPER_ASSIGNMENTS 및 WRAPPER_UPDATES입니다. 전자는 래퍼 함수의 이름, module 및 doc 속성을 직접 할당하도록 지정하고, 후자는 래퍼 함수의 dict 속성 업데이트를 지정합니다.

该函数主要用于装饰器函数的定义中,置于包装函数之前。如果没有对包装函数进行更新,那么被装饰后的函数所具有的元信息就会变为包装函数的元信息,而不是原函数的元信息。

functools.wraps()

语法:

functools.wraps(wrapped[, assigned][, updated]) 

wraps() 简化了 update_wrapper() 函数的调用。它等价于 partial(update_wrapper, wrapped=wrapped, assigned, updated=updated)。

示例:


>>> from functools import wraps
>>> def my_decorator(f):
...   @wraps(f)
...   def wrapper(*args, **kwds):
...     print &#39;Calling decorated function&#39;
...     return f(*args, **kwds)
...   return wrapper

>>> @my_decorator
... def example():
...   """Docstring"""
...   print &#39;Called example function&#39;

>>> example()
Calling decorated function 
Called example function 
>>> example.name
&#39;example&#39; 
>>> example.doc
&#39;Docstring&#39;

如果不使用这个函数,示例中的函数名就会变成 wrapper ,并且原函数 example() 的说明文档(docstring)就会丢失。

위 내용은 Python의 functools 모듈 기능 분석 정보의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.