Я хотел бы запустить многопроцессорную задачу из надстройки Python. Моя проблема в том, что процесс продолжает терпеть неудачу. В основном вылетает ArcMap.
Вот мой основной код:
def function(startOID, endOID, fc):
wrksp = r"c:\temp\mp_addintest\data\test_%s.txt" % (int(startOID) + int(endOID))
# real logic removed to dumb it down
with open(wrksp, 'w') as writer:
writer.write("%s to %s from %s \n" % (startOID, endOID, fc))
return wrksp
class btnMP(object):
"""Implementation for src_addin.MPButton (Button)"""
def __init__(self):
self.enabled = True
self.checked = False
def onClick(self):
pool = None
try:
pythonExe = os.path.join(sys.exec_prefix, 'python.exe')
multiprocessing.set_executable(pythonExe)
pool = multiprocessing.Pool(4)
results = []
for i in xrange(4):
results.append(pool.apply_async(function, [str(1),
str(i),
str("test")]))
pool.close()
pool.join()
for result in results:
print result.get()
except:
del pool
print 'error'
Если я запускаю код вне ArcMap или из набора инструментов, он работает без проблем, но когда я помещаю логику в кнопку, это вызывает сбой arcmap.
Я предполагаю, что ArcMap работает в процессе для всех надстроек Python. Есть ли решение этой проблемы?
Я также попытался добавить в код freeze_support (), но это тоже ничего не дало.
arcgis-desktop
arcgis-10.1
arcpy
python-addin
parallel-processing
кодовая база 5000
источник
источник
Ответы:
Параллельная обработка легче «показана, чем выполнена». В случае вставки всего этого в кнопку, я предполагаю две проблемы:
Хм, смотря дальше, проблема была задокументирована здесь на странице ресурсов ArcGIS. Схема блокировки выглядит как преступник.
источник