import arcpy # 获取用户输入参数 input_feature = arcpy.GetParameterAsText(0) # 输入要素 query_expression = arcpy.GetParameterAsText(1) # 查询表达式 output_feature = arcpy.GetParameterAsText(2) # 输出要素 # 构建查询语句 query = "{} >= {}".format(arcpy.AddFieldDelimiters(input_feature, "面积"), query_expression) # 使用查询语句选择要素 arcpy.MakeFeatureLayer_management(input_feature, "lyr") arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query) # 将选择的要素导出到输出位置 arcpy.CopyFeatures_management("lyr", output_feature) # 清除选择 arcpy.SelectLayerByAttribute_management("lyr", "CLEAR_SELECTION")运行错误:Traceback (most recent call last): File "D:\多对一空间连接\批量删除小面积.py", line 12, in <module> File "c:\program files (x86)\arcgis\desktop10.2\arcpy\arcpy\management.py", line 6688, in SelectLayerByAttribute raise e ExecuteError: ERROR 000358: 无效的表达式 执行(SelectLayerByAttribute)失败。 执行(删除小面)失败。请改正代码
时间: 2024-01-22 21:21:22 浏览: 218
这个错误通常是由于查询表达式中的语法错误导致的。您可以尝试打印出您构建的查询语句,检查其中是否有语法错误。另外,还可以将查询表达式直接硬编码到脚本中,看看是否仍然存在错误。例如:
```
query_expression = "1000" # 直接将查询表达式硬编码为 "1000"
query = "{} >= {}".format(arcpy.AddFieldDelimiters(input_feature, "面积"), query_expression)
```
如果上述代码可以正常运行,那么问题可能在于您输入的查询表达式不符合要求。您可以参考 ArcGIS 帮助文档中关于查询表达式的说明,确保输入的查询表达式是正确的。
相关问题
import arcpy # 获取用户输入参数 input_feature = arcpy.GetParameterAsText(0) # 输入要素 query_expression = arcpy.GetParameterAsText(1) # 查询表达式 output_feature = arcpy.GetParameterAsText(2) # 输出要素 # 构建查询语句 query = "".format(arcpy.AddFieldDelimiters(input_feature, "面积"), query_expression) # 使用查询语句选择要素 arcpy.MakeFeatureLayer_management(input_feature, "lyr") arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query) # 将选择的要素导出到输出位置 arcpy.CopyFeatures_management("lyr", output_feature) # 清除选择 arcpy.SelectLayerByAttribute_management("lyr", "CLEAR_SELECTION")运行错误:Traceback (most recent call last): File "D:\多对一空间连接\批量删除小面积.py", line 15, in <module> NameError: name 'output_feature' is not defined 执行(删除小面)失败。请改正代码
代码中定义了变量 `output_feature` 作为输出要素的路径,但是在构建查询语句和导出要素时都没有使用该变量,导致在执行 `arcpy.CopyFeatures_management("lyr", output_feature)` 时出现了 `NameError: name 'output_feature' is not defined` 的错误。
要解决这个问题,需要将 `output_feature` 变量传递给相应的函数,修改后的代码如下:
```python
import arcpy
# 获取用户输入参数
input_feature = arcpy.GetParameterAsText(0) # 输入要素
query_expression = arcpy.GetParameterAsText(1) # 查询表达式
output_feature = arcpy.GetParameterAsText(2) # 输出要素
# 构建查询语句
query = "{} < {}".format(arcpy.AddFieldDelimiters(input_feature, "面积"), query_expression)
# 使用查询语句选择要素
arcpy.MakeFeatureLayer_management(input_feature, "lyr")
arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query)
# 将选择的要素导出到输出位置
arcpy.CopyFeatures_management("lyr", output_feature)
# 清除选择
arcpy.SelectLayerByAttribute_management("lyr", "CLEAR_SELECTION")
```
修改后的代码中,将查询语句中的占位符 `{}` 替换为了正确的字段和查询表达式,同时在导出要素时使用了 `output_feature` 变量。
import arcpy arcpy.SelectLayerByAttribute_management("lyr", "CLEAR_SELECTION") # 使用查询语句选择要素 arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query) # 获取用户输入参数 input_feature = arcpy.GetParameterAsText(0) # 输入要素 query_expression = arcpy.GetParameterAsText(1) # 查询表达式 output_feature = arcpy.GetParameterAsText(2) # 输出要素 # 构建查询语句 query = "{}".format(arcpy.AddFieldDelimiters(input_feature, "面积") + " >= {}".format(query_expression)) # 使用查询语句选择要素 arcpy.MakeFeatureLayer_management(input_feature, "lyr") arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query) # 将选择的要素导出到输出位置 arcpy.CopyFeatures_management("lyr", output_feature)运行错误:执行: 删除小面 Export_Output_21111 "面积 >= '497477.651982771'" D:\多对一空间连接\多对一空间连接.gdb\突突突 开始时间: Wed May 24 22:20:05 2023 正在运行脚本 删除小面... Failed script 删除小面... Traceback (most recent call last): File "D:\多对一空间连接\批量删除小面积.py", line 3, in <module> File "c:\program files (x86)\arcgis\desktop10.2\arcpy\arcpy\management.py", line 6688, in SelectLayerByAttribute raise e ExecuteError: 执行失败。参数无效。 ERROR 000732: 图层名称或表视图: 数据集 lyr 不存在或不受支持 执行(SelectLayerByAttribute)失败。 执行(删除小面)失败。 失败 在 Wed May 24 22:20:06 2023 (经历的时间: 0.28 秒)请改正代码
可以尝试修改代码如下:
```
import arcpy
# 获取用户输入参数
input_feature = arcpy.GetParameterAsText(0) # 输入要素
query_expression = arcpy.GetParameterAsText(1) # 查询表达式
output_feature = arcpy.GetParameterAsText(2) # 输出要素
# 构建查询语句
query = "{}".format(arcpy.AddFieldDelimiters(input_feature, "面积") + " >= {}".format(query_expression))
# 使用查询语句选择要素
arcpy.MakeFeatureLayer_management(input_feature, "lyr")
arcpy.SelectLayerByAttribute_management("lyr", "NEW_SELECTION", query)
# 将选择的要素导出到输出位置
arcpy.CopyFeatures_management("lyr", output_feature)
# 清除选择
arcpy.SelectLayerByAttribute_management("lyr", "CLEAR_SELECTION")
```
修改后的代码中,先获取了用户输入的参数,然后构建查询语句,并使用`MakeFeatureLayer_management`函数创建名为"lyr"的要素图层。接着使用`SelectLayerByAttribute_management`函数选择符合条件的要素,并将其导出到输出位置。最后使用`SelectLayerByAttribute_management`函数清除选择。
阅读全文