Пример использования concurrent.futures (Backport для 2.7):Получение оригинальный номер строки для исключения в concurrent.futures
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'
Строка "...\_base.py", line 356, in __get_result"
не конечной точке я ожидал увидеть , Можно ли получить реальную строку, где было выбрано исключение? Что-то вроде:
File "C:\test.py", line 3, in f
return x * x # line 03
Python3, кажется, показывает правильный номер строки в этом случае. Почему не может python2.7? И есть ли какое-нибудь обходное решение?
Я также искал ответ на этот вопрос. Благодаря! – drpoo