写一个arcgis10.2.2工具箱python2.7的脚本代码:输入数据,凡是在SHAPE_Area < 多少字符串值情况下的图斑进行自动删除并导出剩余要素
时间: 2024-01-22 17:19:35 浏览: 74
ArcGIS-Python.zip_arcgis python_arcgis script_arcgis 工具_gis添加脚本_
5星 · 资源好评率100%
以下是一个在 ArcGIS 10.2.2 工具箱中使用 Python 2.7 编写的脚本,用于删除 SHAPE_Area 小于特定值的要素并导出剩余要素:
```python
# 导入必要的模块和工具包
import arcpy
from arcpy import env
# 设置工作环境
env.workspace = "C:/data"
env.overwriteOutput = True
# 获取输入要素类和阈值
input_fc = arcpy.GetParameterAsText(0)
threshold = float(arcpy.GetParameterAsText(1))
# 定义要删除的要素的查询条件
query = "SHAPE_Area < {}".format(threshold)
# 使用 arcpy.MakeFeatureLayer 建立要素层
arcpy.MakeFeatureLayer_management(input_fc, "lyr")
# 使用 arcpy.SelectLayerByAttribute 进行要素选择
arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query)
# 使用 arcpy.DeleteFeatures 删除要素
arcpy.DeleteFeatures_management("lyr")
# 使用 arcpy.CopyFeatures 导出剩余要素
output_fc = arcpy.GetParameterAsText(2)
arcpy.CopyFeatures_management("lyr", output_fc)
```
此脚本中,我们首先设置了工作环境,然后从脚本工具参数中获取输入要素类和阈值。接着,我们使用 `arcpy.MakeFeatureLayer` 函数建立要素层,并使用 `arcpy.SelectLayerByAttribute` 进行要素选择。然后,我们使用 `arcpy.DeleteFeatures` 删除要素,最后使用 `arcpy.CopyFeatures` 导出剩余要素。注意,在此脚本中,我们使用了 `arcpy.GetParameterAsText` 函数来获取脚本工具中的输入参数,这样用户就可以在工具对话框中指定这些参数。
阅读全文