重分类 (3D 分析)
摘要
重分类(或更改)栅格中的值。
用法
-
输入栅格必须具有有效的统计数据。如果统计数据不存在,则可使用“数据管理工具”工具箱中的计算统计数据工具来创建这些统计数据。
如果要对值的范围重新分类,除两个输入范围的边界外,范围不应重叠。在发生重叠的位置,较低输入范围的最大值将包含在取值范围中,而较高输入范围的最小值将不包含在取值范围中。
举例来说,如果指定了两个范围,比如将值 1 到 5 重新分类为 100,将 5 到 10 重新分类为 200,则小于或等于 5 的输入值将指定给输出值 100,而大于 5 的输入值(如 5.1)则会指定给 200。
-
如果使用工具对话框,则可通过保存按钮来存储重映射表以供以后使用。使用加载按钮可打开先前通过保存按钮创建的重映射表。
-
建议只加载先前用重分类工具保存的表。表的格式是特定的,且必须含有字段 FROM、TO、OUT 和 MAPPING。
-
默认情况下,输入栅格将被分成重分类表中的九类。
-
如果输入栅格是图层,将从渲染器获取重分类的旧值。如果渲染器已经拉伸过,则重分类将默认为 255 类。
-
重分类的重映射表经过修改后,如果选择新的输入栅格,则这些值将不会更新。如果重分类不适合新的栅格,则可按如下方式重新初始化默认重分类:
- 编辑重分类字段的值或为其选择新值
- 重新启动该工具
-
该工具包含一个用来管理小数位数处理方式的精度控件。
-
将重分类工具用作模型的一部分时:
- 如果该工具的输入源自尚未运行的某个工具,则重分类工具中的重映射参数将一直为空,直到运行了前面的工具且验证了该模型。为避免发生这种情况,请始终先运行前面的工具,然后再将这些工具的输出变量作为输入连接到重分类工具。也可以通过添加条目来创建自定义重分类表。
- 如果将重分类表显示为模型参数,则重分类字段必须显示为变量。不过,不需要将重分类字段设置为模型参数。如果该字段未显示为变量,则在模型工具对话框中,分类按钮和唯一值按钮将不可用。
语法
参数 | 说明 | 数据类型 |
in_raster |
要进行重分类的输入栅格。 | Raster Layer |
reclass_field |
表示要进行重分类的值的字段。 | Field |
remap |
用于定义值的重分类方式的重映射列表。 重映射列表由三部分组成:“自”值、“至”值和“新”值。重映射列表中的各行由分号来分隔,而这三部分则由空格分隔。例如: "0 5 1;5.01 7.5 2;7.5 10 3" | Remap |
out_raster |
输出重分类栅格。 输出将始终为整型。 | Raster Dataset |
missing_values (可选) |
指示重分类表中的缺失值是保持不变还是映射为 NoData。
| Boolean |
代码实例
以下示例显示的是如何将栅格重新分成七类。
import arcpy
from arcpy import env
env.workspace = "C:/sapyexamples/data"
arcpy.Reclassify_3d("C:/data/landuse", "VALUE",
"1 9;2 8;3 1;4 6;5 3;6 2;7 1",
"C:/output/outremap","DATA")
以下示例显示的是根据字符串型字段中的值对输入栅格进行重分类。
# Name: Reclassify_3d_Ex_02.py
# Description: Reclassifies the values in a raster.
# Requirements: 3D Analyst Extension
# Import system modules
import arcpy
from arcpy import env
# Set environment settings
env.workspace = "C:/data"
# Set local variables
inRaster = "landuse"
field = "VALUE"
remapString = "1 9;2 8;3 1;4 6;5 3;6 2;7 1"
outRaster = "C:/output/reclass3d"
# Check out the ArcGIS 3D Analyst extension license
arcpy.CheckOutExtension("3D")
# Execute Reclassify
arcpy.Reclassify_3d(inRaster, field, remapString, outRaster, "DATA")