• 【306】通过ArcPy编写ArcToolbox


    参考:使用 Python 创建工具

    参考:在 Python 工具箱中定义参数数据类型


    基本步骤如下:

    (1)创建一个 Python 脚本,并保存成 .py 文件。

    (2)创建一个自定义工具箱(.tbx 文件),用于存放脚本工具。

    (3)通过脚本添加向导向自定义工具箱中添加工具。

    (4)修改脚本的输入和输出变量,以便它能无缝地整合到地理处理框架中。


    详细说明:

    1. 自定义工具箱

      如下图所示:在 ArcToolbox 上右键》Add Toolbox...,在出现的对话框中选择右上角的“New Toolbox”,即可以新建一个工具箱

      

      

    2. 添加脚本

      如下图所示,在新建的 Toolbox 上右键》Add》Script,然后进入向导模式

      

      (1)添加名称,Name 为工具名称(无空格),Label 为工具显示名称(可以有空格),Description 则是打开工具是显示的说明内容,选择“存储相对路径”有助于工具的转移,不受路径影响。

       

      (2)导入 Python 脚本文件的路径。

      (3)设置工具的参数,包括输入参数和输出参数。

      Display Name 为参数的说明,Data Type 为参数的类型

      常用参数属性如下所示:

    • Type:该属性有三种值,必选、可选以及派生。
    • Direction:该属性定义了该参数是输入参数还是输出参数。
    • MultiValue:如果设置为 NO,则该参数只能设置一个值。如果设置为 YES,则该参数可以设置一列值。
    • Default:默认值,不设置的话,在添加完输入参数后,系统会自动生成输出文件名。
    • Filter:可以限制输入参数的数据类型。可以根据所需要的数据类型,设置各种类型的过滤器。

      常用 Data Type 如下所示:

    • File:通过点击 Filter 属性可以修改扩展名,如下图所示,选择 File,然后填写扩展名,不需要加点。

    • Shapefile:shp 文件。
    • Folder:文件夹,如果想要设置输出文件夹,Direction 属性也要选择 input。
    • Text File:文本文件(txt 文件)。

      

      脚本最后就是生成了对应的文件,若是 shp 文件,如果想要自动添加到当前 data frame 中,可以参考“添加 shp 文件”。

    3. 脚本中接收参数

      通过 GetParameterAsText 和 GetParameter 函数接收工具传递过来的参数。

      GetParameterAsText 函数的语法如下所示:

    <variable> = arcpy.GetParameterAsText (<index>)
    

      脚本工具对话框上的参数与 GetParameterAsText 函数的索引值是一一对应的,分别为0、1、2...

      GetParameterAsText 函数会以字符串的形式接收,GetParameter 函数可以将接收的一系列值存储在列表中。GetParameterAsText 函数接收多值(MultiValue)参数时,会将文本用分号(;)隔开,因此可以通过 split 函数将字符串创建成列表。如下所示:

    import arcpy
    # 第一个参数,为多值的输入参数
    inputFile = arcpy.GetParameterAsText(0)
    # 第二个参数,为输出参数
    outFile = arcpy.GetParameterAsText(1)
    
    # 定义xml列表
    file_xmls = inputFile.split(";")
    

    4. 修改脚本工具

      如下图所示可以修改工具,Edit 可以直接打开 .py 文件;Item Description 可以添加说明内容,包括工具的说明以及每一个参数的详细说明;Properties 可以修改向导里面设置的参数内容,将这些设置修改后,最好将工具箱另存为 .tbx,这样新的工具箱就有了新的设置。

      

    参考: Arcpy基础方法之Tools&Toolboxes

    参考:使用python+Arcpy创建自定义Arctoolbox工具

      对于输入中文容易报错,通过此链接“关于python报错“...ordinal not in range(128)”的解决办法”解决,代码如下:

    import sys
    reload(sys)
    sys.setdefaultencoding('utf-8')
    
  • 相关阅读:
    django with mysql (part-4)
    django with mysql (part-3)
    django with mysql (part-2)
    [LeetCode] 22. 括号生成(回溯/DP)
    [算法]求满足要求的进制(辗转相除(欧几里得算法),求最大公约数gcd)
    [算法]体积不小于V的情况下的最小价值(0-1背包)
    [LeetCode]96. 不同的二叉搜索树(DP,卡特兰数)
    [LeetCode]98. 验证二叉搜索树
    [LeetCode]21. 合并两个有序链表(递归)
    [LeetCode]538. 把二叉搜索树转换为累加树
  • 原文地址:https://www.cnblogs.com/alex-bn-lee/p/8717622.html
Copyright © 2020-2023  润新知