import arcpy import sys # 获取要素类路径和查询条件 feature_class = arcpy.GetParameterAsText(0) query = arcpy.GetParameterAsText(1) if not arcpy.Exists(feature_class): arcpy.AddError("输入的要素类不存在!") sys.exit() # 构建查询语句 expression = arcpy.AddFieldDelimiters(feature_class, "SHAPE_Area") + " < " + query # 使用 arcpy.da.UpdateCursor 删除要素 with arcpy.da.UpdateCursor(feature_class, "*", where_clause=expression) as cursor: for row in cursor: cursor.deleteRow() # 输出要素类到指定路径 output_path = arcpy.GetParameterAsText(2) arcpy.FeatureClassToFeatureClass_conversion(feature_class, output_path, "output_feature_class") # 完成操作并清理内存 del cursor运行错误:Traceback (most recent call last): File "D:\多对一空间连接\批量删除小面积.py", line 22, in <module> File "c:\program files (x86)\arcgis\desktop10.2\arcpy\arcpy\conversion.py", line 1675, in FeatureClassToFeatureClass raise e ExecuteError: 执行失败。参数无效。 ERROR 000732: 输出位置: 数据集 D:\实验2\新建文件地理数据库.gdb\ddd 不存在或不受支持 执行(FeatureClassToFeatureClass)失败。 执行(删除小面)失败。请改正代码
时间: 2024-02-01 07:12:35 浏览: 13
错误提示显示输出位置不存在或不受支持,可能是由于指定的输出路径有误或者输出路径中的地理数据库不存在。可以检查输出路径是否正确,并确认指定的地理数据库已经存在。另外,您可以在代码中添加一些异常处理语句,以便更好地捕获和处理错误。例如,可以使用 try/except 语句来捕获 arcpy 执行过程中可能出现的异常,并使用 arcpy.AddError() 函数将异常信息输出到 ArcGIS 中的“结果”窗口。
相关问题
import arcpy import sys # 获取要素类路径和查询条件 feature_class = arcpy.GetParameterAsText(0) query = arcpy.GetParameterAsText(1) if not arcpy.Exists(feature_class): arcpy.AddError("输入的要素类不存在!") sys.exit() # 构建查询语句 expression = arcpy.AddFieldDelimiters(feature_class, "SHAPE_Area") + " < " + query # 使用 arcpy.da.UpdateCursor 删除要素 with arcpy.da.UpdateCursor(feature_class, "*", where_clause=expression) as cursor: for row in cursor: cursor.deleteRow() # 完成操作并清理内存 del cursor加一个删除成果后导出数据
import arcpy
import sys
# 获取要素类路径和查询条件
feature_class = arcpy.GetParameterAsText(0)
query = arcpy.GetParameterAsText(1)
if not arcpy.Exists(feature_class):
arcpy.AddError("输入的要素类不存在!")
sys.exit()
# 构建查询语句
expression = arcpy.AddFieldDelimiters(feature_class, "SHAPE_Area") + " < " + query
# 使用 arcpy.da.UpdateCursor 删除要素
with arcpy.da.UpdateCursor(feature_class, "*", where_clause=expression) as cursor:
for row in cursor:
cursor.deleteRow()
# 导出更新后的要素类
arcpy.FeatureClassToFeatureClass_conversion(feature_class, "C:/output.gdb", "updated_feature_class")
# 完成操作并清理内存
del cursor
定义要素类和筛选条件 feature_class = arcpy.GetParameterAsText(0) # 设置参数名称为 0 query = arcpy.GetParameterAsText(1) if not arcpy.Exists(feature_class): arcpy.AddError("输入的要素类不存在!") sys.exit() # 构建查询语句 expression = arcpy.AddFieldDelimiters(feature_class, "your_field_name") + " = " + query # 使用 arcpy.da.UpdateCursor 删除要素 with arcpy.da.UpdateCursor(feature_class, "*", where_clause=expression) as cursor: for row in cursor: cursor.deleteRow() # 完成操作并清理内存 del cursor运行错误:Traceback (most recent call last): File "D:\多对一空间连接\批量删除小面积.py", line 4, in <module> NameError: name 'feature_class' is not defined 执行(删除小面)失败。请改正代码
根据你提供的代码和错误提示,可能是由于 feature_class 变量没有被正确定义导致的。请检查你的代码,确保在获取参数值之后,feature_class 变量已经被正确赋值。
你可以尝试修改代码如下:
```python
import arcpy
import sys
# 获取要素类路径和查询条件
feature_class = arcpy.GetParameterAsText(0)
query = arcpy.GetParameterAsText(1)
if not arcpy.Exists(feature_class):
arcpy.AddError("输入的要素类不存在!")
sys.exit()
# 构建查询语句
expression = arcpy.AddFieldDelimiters(feature_class, "your_field_name") + " = " + query
# 使用 arcpy.da.UpdateCursor 删除要素
with arcpy.da.UpdateCursor(feature_class, "*", where_clause=expression) as cursor:
for row in cursor:
cursor.deleteRow()
# 完成操作并清理内存
del cursor
```
请将上述代码中的 "your_field_name" 修改为你要删除的字段名称。如果还有其他问题,请提供更多具体的错误信息。