~ (Boolean Not) operator

需要 Spatial Analyst 许可。

获得 Image Analyst 许可后可用。

摘要

对此输入栅格的各像元值执行“布尔求反”(非)运算。

插图

“布尔非”图示
OutRas = ~ Raster("InRas1")

说明

输入(操作数)是栅格时,~ 运算符将执行“布尔非”运算。 如果输入(操作数)是数值,则 ~ 运算符将执行“按位非”运算。 有关如何使用运算符的详细信息,请参阅使用运算符

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

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

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

要进行此布尔运算,仅需单个输入。

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

如果输入是多波段栅格,则输出也将为多波段栅格。 该运算符将在输入中的每个波段上执行操作。

如果输入为多维栅格,则将处理所有变量的所有剖切,并且输出将为多维栅格。

参数

操作数说明数据类型
in_raster_or_constant

“布尔非”运算中所使用的输入。

Raster Layer | Constant

代码示例

~(布尔非)示例 1(Python 窗口)

本例对输入栅格执行“布尔非”(求反)运算。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outBooleanNot = ~ Raster("degs")
outBooleanNot.save("C:/sapyexamples/output/outboolnot.tif")
~(布尔非)示例 2(独立脚本)

本例对输入栅格执行“布尔非”(求反)运算。

# Name: Op_BooleanNot_Ex_02.py
# Description: Performs a Boolean complement (NOT) operation on the
#              cell values of an input raster
# 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
inRaster = Raster("degs")

# Execute BooleanNot
outBooleanNot = ~ inRaster

# Save the output 
outBooleanNot.save("C:/sapyexamples/output/outboolnot")

相关主题