>백엔드 개발 >파이썬 튜토리얼 >Python Multiprocessing의 'PicklingError: Can't pickle'을 해결하는 방법은 무엇입니까?

Python Multiprocessing의 'PicklingError: Can't pickle'을 해결하는 방법은 무엇입니까?

DDD
DDD원래의
2024-12-15 08:24:10887검색

How to Solve Python Multiprocessing's

Python 다중 처리의 PicklingError

Python 다중 처리를 사용할 때 "PicklingError: Can't pickle <'function' 유형을 지정할 수 없습니다"가 발생할 수 있습니다. >: 속성 조회 __builtin__.function 실패" 오류. 작업자 프로세스에 함수를 보내려고 하는데 해당 함수가 모듈의 최상위 수준에 정의되어 있지 않은 경우에 발생합니다.

중첩 함수 문제

In 특정 경우에는 중첩 함수를 호출하여 피클링하는 함수로 인해 오류가 발생할 수 있습니다. 외부 함수 f()가 최상위 수준에 정의되어 있더라도 중첩 함수 h()가 포함된 함수 g()를 호출하면 다중 처리는 중첩 함수를 피클링하려고 시도하고 실패합니다.

해결책

이 문제를 해결하려면 피클하려는 함수를 모듈의 최상위 수준으로 이동하세요. 또는 중첩된 함수를 호출하는 별도의 함수를 최상위 수준에서 생성하고 대신 해당 함수를 피클할 수 있습니다.

예:

# Original code
def f():
    g()

def g():
    h()

# Corrected code
def f():
    wrapper_function()

def wrapper_function():
    g()
    h()

최상위 수준에서 Wrapper_function()을 정의하여 그리고 피클링을 하면 피클링 에러를 피할 수 있습니다.

추가 고려 사항

  • 람다 함수 및 함수 포인터 피클링은 지원되지 않습니다.
  • 파일 핸들이나 데이터베이스 연결과 같이 피클할 수 없는 개체에 액세스하는 함수는 피클링할 수 없습니다.
  • 일반적으로 모듈에서 함수를 사용하려는 경우 모듈의 최상위 수준에서 함수를 정의하는 것이 좋습니다. 다중 처리.

위 내용은 Python Multiprocessing의 'PicklingError: Can't pickle'을 해결하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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