Terrain-Punkte löschen (ArcGIS 3D Analyst)
Zusammenfassung
Löscht Punkte innerhalb eines festgelegten Interessensbereichs aus Features, die an einem Terrain-Dataset beteiligt sind.
Verwendung
-
Durch das Löschen von Punkten aus einer eingebetteten Feature-Class wird das Terrain ungültig. Führen Sie das Werkzeug Terrain berechnen aus, nachdem Sie Punkte gelöscht haben.
Falls es sich um ein SDE-Terrain handelt, ist eine Registrierung als versioniert erforderlich.
Syntax
Parameter | Erläuterung | Datentyp |
in_terrain |
Das Eingabe-Terrain-Dataset. | Terrain Layer |
data_source |
Eine oder mehrere Feature-Classes, aus denen Punkte entfernt werden. | String |
polygon_features_or_extent | Legt den Bereich fest, aus dem Punkte entfernt werden. Sie können eine Polygon-Feature-Class oder eine Ausdehnung verwenden. Wenn Ausdehnungswerte gewünscht werden, verwenden Sie ein arcpy.Extent-Objekt. | Feature Layer; Extent |
Codebeispiel
Anhand des folgenden Beispiels wird die Verwendung dieses Werkzeugs im Python-Fenster veranschaulicht:
import arcpy
from arcpy import env
arcpy.CheckOutExtension("3D")
env.workspace = "C:/data"
arcpy.DeleteTerrainPoints_3d("sample.gdb/featuredataset/terrain",
"mass_pts_embed", "1379938 235633 1382756 237681")
Im folgenden Beispiel wird die Verwendung dieses Werkzeugs in einem eigenständigen Python-Skript veranschaulicht:
'''**********************************************************************
Name: Delete Terrain Outliers
Description: Uses Locate Outliers to identify outlier points in
a terrain dataset, and eliminates the outliers from the
terrain with Delete Terrain Points.
**********************************************************************'''
# Import system modules
import arcpy
import exceptions, sys, traceback
from arcpy import env
try:
arcpy.CheckOutExtension('3D')
# Set Local Variables
env.workspace = 'C:/data'
terrain = 'test.gdb/featuredataset/sample_terrain'
terrainPt = 'elevation_pts' # name of terrain point data source
outliers = 'in_memory/outliers'
# Execute LocateOutliers
arcpy.ddd.LocateOutliers(terrain, outliers, 'APPLY_HARD_LIMIT', -10,
350, 'APPLY_COMPARISON_FILTER', 1.2, 120,
0.8, 8000)
# Execute Delete Terrain Points
arcpy.ddd.DeleteTerrainPoints(terrain, terrainPt, outliers)
arcpy.CheckInExtension('3D')
except arcpy.ExecuteError:
print arcpy.GetMessages()
except:
# Get the traceback object
tb = sys.exc_info()[2]
tbinfo = traceback.format_tb(tb)[0]
# Concatenate error information into message string
pymsg = 'PYTHON ERRORS:\nTraceback info:\n{0}\nError Info:\n{1}'\
.format(tbinfo, str(sys.exc_info()[1]))
msgs = 'ArcPy ERRORS:\n {0}\n'.format(arcpy.GetMessages(2))
# Return python error messages for script tool or Python Window
arcpy.AddError(pymsg)
arcpy.AddError(msgs)