Пример использования concurrent.futures(backport for 2.7):
import concurrent.futures # line 01
def f(x): # line 02
return x * x # line 03
data = [1, 2, 3, None, 5] # line 04
with concurrent.futures.ThreadPoolExecutor(len(data)) as executor: # line 05
futures = [executor.submit(f, n) for n in data] # line 06
for future in futures: # line 07
print(future.result()) # line 08
Вывод:
1
4
9
Traceback (most recent call last):
File "C:\test.py", line 8, in <module>
print future.result() # line 08
File "C:\dev\Python27\lib\site-packages\futures-2.1.4-py2.7.egg\concurrent\futures\_base.py", line 397, in result
return self.__get_result()
File "C:\dev\Python27\lib\site-packages\futures-2.1.4-py2.7.egg\concurrent\futures\_base.py", line 356, in __get_result
raise self._exception
TypeError: unsupported operand type(s) for *: 'NoneType' and 'NoneType'
String "...\_base.py", line 356, in __get_result"
- это не конечная точка, которую я ожидал увидеть. Можно ли получить реальную строку, где было выбрано исключение? Что-то вроде:
File "C:\test.py", line 3, in f
return x * x # line 03
В этом случае Python3 показывает правильный номер строки. Почему не может python2.7? И есть ли способ обхода?