Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Python Multiprocessing Lib Error (AttributeError: __exit__)

Am getting this error when using the pool.map(funct, iterable):

AttributeError: __exit__ 

No Explanation, only stack trace to the pool.py file within the module.

using in this way:

with Pool(processes=2) as pool:    pool.map(myFunction, mylist)    pool.map(myfunction2, mylist2) 

I suspect there could be a problem with the picklability (python needs to pickle, or transform list data into byte stream) yet I'm not sure if this is true or if it is how to debug.

EDIT: new format of code that produces this error :

def governingFunct(list):     #some tasks     def myFunction():          # function contents     with closing(Pool(processes=2)) as pool:          pool.map(myFunction, sublist)          pool.map(myFunction2, sublist2) 

ERROR PRODUCED:

PicklingError: Can't pickle <type 'function'>: attribute lookup __builtin__.function failed 
like image 534
sidewaiise Avatar asked Sep 22 '14 07:09

sidewaiise


2 Answers

In Python 2.x and 3.0, 3.1 and 3.2, multiprocessing.Pool() objects are not context managers. You cannot use them in a with statement. Only in Python 3.3 and up can you use them as such. From the Python 3 multiprocessing.Pool() documentation:

New in version 3.3: Pool objects now support the context management protocol – see Context Manager Types. __enter__() returns the pool object, and __exit__() calls terminate().

For earlier Python versions, you could use contextlib.closing(), but take into account this'll call pool.close(), not pool.terminate(). Terminate manually in that case:

from contextlib import closing  with closing(Pool(processes=2)) as pool:     pool.map(myFunction, mylist)     pool.map(myfunction2, mylist2)     pool.terminate() 

or create your own terminating() context manager:

from contextlib import contextmanager  @contextmanager def terminating(thing):     try:         yield thing     finally:         thing.terminate()  with terminating(Pool(processes=2)) as pool:     pool.map(myFunction, mylist)     pool.map(myfunction2, mylist2) 
like image 179
Martijn Pieters Avatar answered Oct 08 '22 21:10

Martijn Pieters


with statement is for object that have __enter__ and __exit__ functions, i.e. Context Manager Types
multiprocessing.Pool is not Context Manager Type. try do the following:

pool = Pool(processes=2) pool.map(myFunction, mylist) pool.map(myfunction2, mylist2) 
like image 41
Elisha Avatar answered Oct 08 '22 21:10

Elisha