>  기사  >  백엔드 개발  >  예제 분석 functools 모듈 기능

예제 분석 functools 모듈 기능

Y2J
Y2J원래의
2017-05-09 14:54:091564검색

이 글에서는 주로 functools 모듈의 Python 기능에 대한 분석을 소개합니다. 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) [, 할당됨][, 업데이트됨])

이 함수는 래퍼 함수(래퍼)를 원래 함수처럼 보이도록 업데이트하는 데 사용됩니다. 선택적 매개변수는 튜플이고, 할당된 튜플은 속성 을 원래 함수의 값으로 직접 대체하도록 지정하고, 업데이트된 튜플은 원래 함수에 대해 업데이트할 속성을 지정합니다. 이 두 매개변수의 기본값은 모듈 수준 상수인 WRAPPER_ASSIGNMENTS 및 WRAPPER_UPDATES입니다. 전자는 래퍼 함수의 이름, module 및 doc 속성을 직접 할당하도록 지정하고, 후자는 래퍼 함수의 dict 속성 업데이트를 지정합니다. 이 함수는 주로 데코레이터 함수 정의에 사용되며 래퍼 함수 앞에 위치합니다. 래퍼 함수가 업데이트되지 않으면 데코레이팅된 함수의 메타정보는 원래 함수의 메타정보가 아닌 래퍼 함수의 메타정보가 됩니다.

functools.wraps()


구문:

functools.wraps(wrapped[, 할당됨][, 업데이트됨])


wraps()는 update_wrapper() 함수 호출을 단순화합니다. 이는 부분(업데이트_래퍼, 래핑=래핑, 할당, 업데이트=업데이트)과 동일합니다.

예:

>>> 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;

이 함수를 사용하지 않으면 예제의 함수 이름이 래퍼가 되고 원래 함수 example()의 문서(docstring)가 손실됩니다.

【관련 추천】

1. Python 무료 동영상 튜토리얼

2. Python 기본 입문 튜토리얼

3. Python이 데이터 수집을 만나다

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

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