
五、处理地理数据异常【arcpy】
- Published on
处理地理数据异常
对于 Python 程序的通用错误
在运行 ArcPy 程序中,大多数异常都是 Python 产生的:
语法错误(SyntaxError):代码不符合 Python 语法规则,通常是由于拼写错误、缺少冒号、括号不匹配等引起的。
名称错误(NameError):尝试使用一个未定义的变量或函数名称。
类型错误(TypeError):操作或函数应用于不适当的类型的对象。
索引错误(IndexError):尝试访问列表、元组或字符串等序列类型的元素时使用了无效的索引。
键错误(KeyError):尝试使用字典中不存在的键。
文件不存在错误(FileNotFoundError):尝试打开或读取一个不存在的文件。
除零错误(ZeroDivisionError):尝试进行除以零的操作。
值错误(ValueError):传递给函数的参数类型正确,但是值不合适。
属性错误(AttributeError):尝试访问对象没有的属性。
异常处理错误(ExceptionHandlingError):在异常处理语句中出现错误,例如错误的语法或逻辑。
这只是一些常见的错误异常,实际上 Python 还有很多其他的异常类型。在编写代码时,应该注意捕获和处理这些异常,以便更好地调试和处理错误。
捕捉 ArcPy 工具的错误
当地理处理工具写入错误消息时,ArcPy 将生成系统错误。具体而言,当地理处理工具运行失败时,它将引发 ExecuteError 异常,该异常可用于处理特定的地理处理错误。它不是 Python 内置异常类之一,但它是由 ArcPy 生成的,因此必须使用 arcpy.ExecuteError
类。
import arcpy
arcpy.env.workspace = "C:/Data"
in_features = "streams.shp"
out_features = "streams.shp"
try:
arcpy.CopyFeatures_management(in_features, out_features)
except arcpy.ExecuteError: # 捕获所有地理处理错误
print(arcpy.GetMessages(2))
except: # 捕获与地理处理无关的任何其他错误
print("There has been a nontool error.")
由于输入要素类和输出要素类不能相同,“复制要素”工具会生成错误,如下所示:
Failed to execute. Parameters are not valid.ERROR 000725: Output Feature Class: Dataset C:/Data\streams.shp already exists.Failed to execute (CopyFeatures).
在复杂的脚本中,若难以确定错误的精确位置,可以使用 Python 的traceback
模块或 IDE 工具进行调试。
推荐社区:
ArcGIS Python 系列教程
感谢阅读本篇ArcGIS Python教程!如果您想进一步提升ArcPy技能,下面是一些推荐资源:
如有问题或建议,欢迎在文章评论区留言或关注我的微信公众号:renhai-lab