五、处理地理数据异常【ArcGIS Python系列】

处理地理数据异常

对于 Python 程序的通用错误

在运行 ArcPy 程序中,大多数异常都是 Python 产生的:

  1. 语法错误(SyntaxError):代码不符合 Python 语法规则,通常是由于拼写错误、缺少冒号、括号不匹配等引起的。

  2. 名称错误(NameError):尝试使用一个未定义的变量或函数名称。

  3. 类型错误(TypeError):操作或函数应用于不适当的类型的对象。

  4. 索引错误(IndexError):尝试访问列表、元组或字符串等序列类型的元素时使用了无效的索引。

  5. 键错误(KeyError):尝试使用字典中不存在的键。

  6. 文件不存在错误(FileNotFoundError):尝试打开或读取一个不存在的文件。

  7. 除零错误(ZeroDivisionError):尝试进行除以零的操作。

  8. 值错误(ValueError):传递给函数的参数类型正确,但是值不合适。

  9. 属性错误(AttributeError):尝试访问对象没有的属性。

  10. 异常处理错误(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 Pro 和Arcpy过程中的总结,记下来方便回看,最新版本会优先发布在我的博客GITHUB

【ArcGIS Python 系列】教程部分:

【ArcGIS Python 系列】jupyter notebook:

托管在 Github:Urban-Spatial-Data-Analysis-Notebook/4-空间数据分析/4.2-ArcGIS Python 系列 at main · renhai-lab/Urban-Spatial-Data-Analysis-Notebook · GitHub


如果你觉得本系列文章有用,欢迎关注博客,点赞 👍 和收藏,也欢迎在评论区讨论,也欢迎访问我的爱发电支持我,或者对此文章进行赞赏。

donate

其他平台账号:
donate


五、处理地理数据异常【ArcGIS Python系列】
https://blog.renhai.online/archives/4.2.6-%E5%A4%84%E7%90%86%E5%9C%B0%E7%90%86%E6%95%B0%E6%8D%AE%E5%BC%82%E5%B8%B8
作者
Renhai
发布于
2023年08月29日
更新于
2024年06月19日
许可协议