Multipart zu Singlepart (Data Management)
Zusammenfassung
Erstellt durch Trennung von Multipart-Eingabe-Features eine Feature-Class mit Singlepart-Features.
Abbildung
Verwendung
-
Die Attribute der Eingabe-Features werden in der Ausgabe-Feature-Class beibehalten. Das Feld "ORIG_FID" wird der Ausgabe-Feature-Class hinzugefügt und auf die IDs des Eingabe-Features gesetzt.
-
Die einzelnen Teile des Multipart-Eingabe-Features werden in der Ausgabe-Feature-Class zu individuellen Singlepart-Features. Features, die bereits Singlepart sind, sind davon nicht betroffen.
-
Die meisten Ausgabe-Feature-Typen sind mit den Eingabetypen identisch (Eingabepolygone bleiben Polygone; Eingabelinien bleiben Linien). Eine Ausnahme ist allerdings, wenn die Eingabe-Features vom Typ "Multipoint" sind. Die Ausgabe-Feature-Class ist dann vom Typ "Point".
-
Mit dem Werkzeug „Zusammenführen“ (Dissolve) lassen sich aus Singlepart-Features mit einem gemeinsamen Feldwert (beispielsweise ORIG_FID) Multipart-Features erstellen.
Syntax
Parameter | Erläuterung | Datentyp |
in_features |
Die Eingabe-Features können jedes beliebige unterstützte Format aufweisen. | Feature Layer |
out_feature_class |
Die Ausgabe-Feature-Class, die Features enthält, die sich je nach Eingabe-Feature-Typ ändern. | Feature Class |
Codebeispiel
Mit dem folgenden Skript im Python-Fenster wird veranschaulicht, wie Sie die Funktion "MultipartToSinglepart" im unmittelbaren Modus verwenden.
import arcpy from arcpy import env env.workspace = "C:/data" arcpy.MultipartToSinglepart_management("landuse.shp", "c:/output/output.gdb/landuse_singlepart")
Das folgende eigenständige Skript ist ein einfaches Beispiel für die Anwendung der Funktion "MultipartToSinglepart" in einer Scripting-Umgebung.
# Name: MultipartToSinglepart_Example2.py # Description: Break all multipart features into singlepart features, # and report which features were separated. # Author: ESRI # import system modules import arcpy from arcpy import env # Set environment settings env.workspace = "C:/data/landcovers.gdb" # Create variables for the input and output feature classes inFeatureClass = "vegetation" outFeatureClass = "vegetation_singlepart" # Use error trapping in case a problem occurs when running the tool try: # Run the tool to create a new fc with only singlepart features arcpy.MultipartToSinglepart_management(inFeatureClass,outFeatureClass) # Check if there is a different number of features in the output # than there was in the input # Get the results of GetCount for input and output resultIn = arcpy.GetCount_management(inFeatureClass) resultOut = arcpy.GetCount_management(outFeatureClass) if (resultIn.getOutput(0) == resultOut.getOutput(0)): print "The number of features in the input is the same as in the output," +\ "so no multipart features were found" else: # If there is a difference, print out the FID of the input features # which were multipart arcpy.Frequency_analysis(outFeatureClass, outFeatureClass + "_freq", "ORIG_FID") # Use a search cursor to go through the table, and print the ORIG_FID print "Here are the FIDs of all the multipart features from " + inFeatureClass rows = arcpy.SearchCursor(outFeatureClass + "_freq", "\"FREQUENCY\" > 1") row = rows.next() while row: print int(row.ORIG_FID) row = rows.next() except Exception, e: # If an error occurred, print line number and error message import traceback, sys tb = sys.exc_info()[2] print "Line %i" % tb.tb_lineno print e.message