^ (布尔异或) (arcpy.sa)

摘要

对两个输入栅格的像元值执行“布尔异或”运算。

插图

Boolean XOr illustration
OutRas = Raster("InRas1") ^ Raster("InRas2")

讨论

当一个或多个输入(操作数)是栅格时,^ 运算符将执行“布尔异或”运算。如果两个输入(操作数)都为数值,则 ^ 运算符将执行“按位异或”运算。有关如何使用运算符的详细信息,请参阅使用运算符

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

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

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

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

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

如果输入值为浮点型,则值会在执行布尔运算前通过截断转换为整型值。输出值始终是整数。

执行“布尔异或”运算的另一个方法为 a ^= b,其为 a = a ^ b 的另一种写法。

语法

in_raster_or_constant1 ^ in_raster_or_constant2
操作数说明数据类型
in_raster_or_constant1

“布尔异或”运算中所使用的第一个输入。

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

Raster Layer | Constant
in_raster_or_constant2

“布尔异或”运算中所使用的第二个输入。

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

Raster Layer | Constant

返回值

名称说明数据类型
out_raster

输出栅格对象。

输出值为 0 或 1。

Raster

代码实例

^ (布尔异或)示例 1(Python 窗口)

本例对两个输入栅格执行“布尔异或”运算。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outBooleanXOr = Raster("degs") ^ Raster("negs")
outBooleanXOr.save("C:/sapyexamples/output/outboolxor.tif")
^ (布尔异或)示例 2(独立脚本)

本例对两个输入栅格执行“布尔异或”运算。

# Name: Op_BooleanXOr_Ex_02.py
# Description: Performs a Boolean Exclusive Or operation on the
#              cell values of two input rasters
# 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")

# Check out the ArcGIS Spatial Analyst extension license
arcpy.CheckOutExtension("Spatial")

# Execute BooleanXOr
outBooleanXOr = inRaster1 ^ inRaster2

# Save the output 
outBooleanXOr.save("C:/sapyexamples/output/outboolxor")

环境

相关主题

5/10/2014