Vorrei eseguire un'attività multiprocessore da uno strumento aggiuntivo Python. Il mio problema è che il processo continua a fallire. Fondamentalmente si arresta in modo anomalo ArcMap.
Ecco il mio codice di base:
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'
Se eseguo il codice all'esterno di ArcMap o da una casella degli strumenti, funziona senza problemi, ma quando inserisco la logica in un pulsante, provoca l'arresto anomalo di arcmap.
La mia ipotesi è che ArcMap sia in esecuzione per tutti i componenti aggiuntivi di Python. C'è un problema per questo problema?
Ho provato ad aggiungere freeze_support () anche al codice, ma anche quello non ha fatto nulla.