----- Original Message ----- > From: "Oscar Benjamin" <oscar.j.benja...@gmail.com> > A simple way to approach this could be something like: > > #!/usr/bin/env python3 > > import math > import multiprocessing > > def sqrt(x): > if x < 0: > return 'error', x > else: > return 'success', math.sqrt(x) > > if __name__ == "__main__": > numbers = [1, 2, 3, -1, -3] > pool = multiprocessing.Pool() > for ret, val in pool.imap(sqrt, numbers): > if ret == 'error': > raise ValueError(val) > print(val) > > Just replace the raise statement with whatever you want to do (write > to a file etc). Since all errors are handled in the master process > there are no issues with writing to a file. > > -- > Oscar
The main problem with this approach is that it does not handle unexpected exceptions within subprocesses. JM -- IMPORTANT NOTICE: The contents of this email and any attachments are confidential and may also be privileged. If you are not the intended recipient, please notify the sender immediately and do not disclose the contents to any other person, use it for any purpose, or store or copy the information in any medium. Thank you. -- https://mail.python.org/mailman/listinfo/python-list