Résumé
Determines if a tool is running synchronous or asynchronous. When a tool is synchronous, the results are automatically returned, but no other action may be taken until the tool has completed. All non-server tools are synchronous. Server tools may be asynchronous, meaning that once the tool has been submitted to the server, other functionality can be run without waiting, and the results must be explicitly requested from the server.
Syntaxe
IsSynchronous (tool_name)
Paramètre | Explication | Type de données |
tool_name | The name of the tool to determine if it is synchronous. | String |
Valeur renvoyée
Type de données | Explication |
Boolean | A return Boolean value of True indicates the tool is synchronous. |
Exemple de code
IsSynchronous example
Determine if a server tool is running synchronous.
import time
import arcpy
# Add server toolbox from a local ArcGIS for Server
arcpy.ImportToolbox("pondermatic;buffertools")
# Create and load a recordset object for the tool's input
record_set = arcpy.RecordSet()
record_set.load("c:/temp/lines.shp")
# Run the server tool
results = arcpy.BufferLines_mytools(record_set, "100")
# If the tool is asynchronous, wait until the task is finished (status = 4)
if not arcpy.IsSynchronous("BufferLines"):
while results.status < 4:
time.sleep(0.1)
# Get output from task and export to a feature class on disk
result = results.getOutput(0)
result.save("c:/temp/bufferlines.shp")