!= (Relational Not Equal) operator

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

描述

在第一个栅格不等于第二个栅格时为像元返回 1,否则返回 0。

插图

不等于(关系)运算符图示
OutRas = Raster("InRas1") != 2

讨论

如果第一个栅格数据不等于第二个栅格数据则为像元返回 1,否则返回 0。

使用具有栅格输入的运算符时,结果将为栅格。但是,如果所有输入为数字,那么结果也是数字。

当表达式中使用多个运算符时,其不一定按照从左到右的顺序执行。具有最高优先值的运算符将首先执行。有关运算符优先级的详细信息,请参阅运算符优先级表。您可使用括号来控制执行顺序。

布尔型(~&^|)运算符具有比关系(<<=>>===!=)运算符更高的优先级。因此,当布尔型运算符在相同表达式中用作关系运算符时,布尔型运算符将被首先执行。要改变执行顺序,请使用括号。

当在单个表达式中连续使用多个关系运算符和/或布尔运算符时,在某些情况下它可能无法执行。要避免此潜在问题,请在表达式中使用适当的括号,以便明确地定义运算符的执行顺序。有关详细信息,请参阅复杂语句规则

要进行该运算,需要两个输入值。

使用此运算符时输入的顺序并不重要。

如果两个输入都是单波段栅格,或者输入之一是常量,则输出将是单波段栅格。

如果两个输入都是多波段栅格,或者输入之一是常量,则输出将是多波段栅格。每个多波段输入中的波段数必须相同。

该运算符将在一个输入的每个波段上针对另一输入的相应波段执行操作。如果输入之一是多波段栅格,而另一个输入是常量,则该运算符将针对多波段输入中每个波段的常量值执行操作。

语法

in_raster_or_constant1 != in_raster_or_constant2
操作数说明数据类型
in_raster_or_constant1

本输入将与第二个输入比较是否不等。

如果输入之一是栅格并且其他输入是标量,则通过对输入栅格中的每个像元执行评估来创建输出栅格。

Raster Layer | Constant
in_raster_or_constant2

本输入将与第一个输入比较是否不等。

如果输入之一是栅格并且其他输入是标量,则通过对输入栅格中的每个像元执行评估来创建输出栅格。

Raster Layer | Constant

返回值

名称说明数据类型
out_raster

输出栅格对象。

第一个输入的像元值与第二个输入的像元值不相等时,输出像元值为 1。如果两个值相等,则输出值为 0。

Raster

代码示例

!=(不等于)示例 1(Python 窗口)

本例对两个输入栅格执行“不等于”运算。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outNotEqual = Raster("degs") != Raster("negs")
outNotEqual.save("C:/sapyexamples/output/outne")
!=(不等于)示例 2(独立脚本)

本例对两个输入栅格执行“不等于”运算。

# Name: Op_NotEqual_Ex_02.py
# Description: Performs a relational not-equal operation on two
#              inputs on a cell-by-cell basis
# 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 NotEqual
outNotEqual = inRaster1 != inRaster2

# Save the output 
outNotEqual.save("C:/sapyexamples/output/outnotequal")

相关主题