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 중국어 웹사이트의 기타 관련 기사를 참조하세요!