操作数 | 说明 | 数据类型 |
in_raster_or_constant1 | 本输入将与第二个输入比较是否相等。 如果输入之一是栅格并且其他输入是标量,则通过对输入栅格中的每个像元执行评估来创建输出栅格。 | Raster Layer | Constant |
in_raster_or_constant2 | 本输入将与第一个输入比较是否相等。 如果输入之一是栅格并且其他输入是标量,则通过对输入栅格中的每个像元执行评估来创建输出栅格。 | Raster Layer | Constant |
需要 Spatial Analyst 许可。
获得 Image Analyst 许可后可用。
摘要
在“分析”窗口中,以逐个像元比较的方式对两个输入执行等于关系运算。
插图
说明
如果第一个栅格数据等于第二个栅格数据则为像元返回 1,否则返回 0。
使用具有栅格输入的运算符时,结果将为栅格。 但是,如果所有输入为数字,则结果也是数字。
当表达式中使用多个运算符时,其不一定按照从左到右的顺序执行。 具有最高优先值的运算符将首先执行。 有关详细信息,请参阅在 Map Algebra 中使用运算符中的运算符优先级表。 您可使用括号来控制执行顺序。
布尔型(~、&、^、|)运算符具有比关系(<、<=、>、>=、==、!=)运算符更高的优先级。 因此,当布尔型运算符在相同表达式中用作关系运算符时,布尔型运算符将被首先执行。 要改变执行顺序,请使用括号。
当在单个表达式中连续使用多个关系运算符和/或布尔运算符时,在某些情况下它可能无法执行。 要避免此潜在问题,请在表达式中使用适当的括号,以便明确地定义运算符的执行顺序。 有关详细信息,请参阅构建复杂语句的复杂语句规则部分。
要进行该运算,需要两个输入值。
使用此运算符时输入的顺序并不重要。
输出值始终是整数。
如果两个输入都是单波段栅格,或者输入之一是常量,则输出将是单波段栅格。
如果两个输入都是多波段栅格,则运算符将从一个输入对每个波段执行运算,而输出将为多波段栅格。 每个多波段输入中的波段数必须相同。
如果输入之一是多波段栅格,而另一个输入是常量,则该运算符将针对多波段输入中每个波段的常量值执行预算,而输出将为多波段栅格。
如果两个输入都是具有相同数量变量的多维栅格,则运算符将对具有相同维度值的所有切片执行运算,而输出将为多维栅格。 输入中的变量必须具有相同维度或常用维度,但不能包含不常用维度。
如果两个输入均具有一个变量但名称不同,请将 matchMultidimensionalVariable 地理处理环境设置为 False 以执行该运算。
如果输入中的一个是多维栅格,而另一个输入是常量,则运算符将针对常量值对所有变量的所有切片执行运算,并且输出将为多维栅格。
参数
代码示例
本例对两个输入栅格执行“等于”运算。
import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outEqualTo = Raster("degs") == Raster("negs")
outEqualTo.save("C:/sapyexamples/output/outequalto.tif")
本例对两个输入栅格执行“等于”运算。
# Name: Op_EqualTo_Ex_02.py
# Description: Performs a relational equal-to operation on two inputs
# on a cell-by-cell basis within the Analysis window
# Requirements: Spatial Analyst Extension
# Import system modules
import arcpy
from arcpy import env
from arcpy.sa import *
# Set environment settings
env.workspace = "C:/sapyexamples/data"
# Set local variables
inRaster1 = Raster("degs")
inRaster2 = Raster("negs")
# Execute EqualTo
outEqualTo = inRaster1 == inRaster2
# Save the output
outEqualTo.save("C:/sapyexamples/output/outequalto")