~ (Булево НЕ) (arcpy.sa)

Резюме

Выполняет булеву операцию НЕ для значений ячеек входного растра.

Рисунок

Иллюстрация инструмента Логическое отрицание (Boolean Not)
OutRas = ~ Raster("InRas1")

Обсуждение

Оператор ~ выполняет булеву операцию НЕ, когда входное значение является растром. Если входное значение является числом, оператор ~ выполняет побитовую операцию НЕ. Дополнительную информацию о работе с операторами можно найти в разделе Работа с операторами.

Если в выражении используется несколько операторов, они не обязательно выполняются слева направо. Оператор с высшим значением приоритета будет выполнен первым. Более подробно о приоритете операторов см. в таблице приоритета операторов. Порядок выполнения можно изменить с помощью скобок.

Уровень приоритета Булевых операторов (~, &, ^, |) выше, чем у реляционных операторов (<, <=, >, >=, ==, !=). Поэтому, если в одном выражении используются Булевы и реляционные операторы, в первую очередь выполняются булевы операторы. Чтобы изменить порядок выполнения, используйте скобки.

Если Булевы и/или реляционные операторы последовательно используются в одном выражении, в некоторых случаях его выполнение может завершиться неудачей. Во избежание потенциальных проблем, используйте соответствующие скобки в выражении, чтобы четко определить порядок выполнения операторов. Для получения более подробной информации см. Правила комплексного оператора.

Для выполнения этой Булевой операции необходимо наличие только одного входного файла.

Если входными данными служат значения с плавающей точкой, они преобразуются в целые числа путем усечения до выполнения Булевой операции. Выходные значения всегда целочисленные.

Синтаксис

~ in_raster_or_constant
ОперандОбъяснениеТип данных
in_raster_or_constant

Входные данные, которые будут использоваться в булевой операции НЕ.

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"
outBooleanNot = ~ Raster("degs")
outBooleanNot.save("C:/sapyexamples/output/outboolnot.tif")
~ (Булево НЕ), пример 2 (автономный скрипт)

В этом примере на входном растре выполняется булева операция Not (дополнительно).

# 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")

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

# Execute BooleanNot
outBooleanNot = ~ inRaster

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

Параметры среды

Связанные темы

9/11/2013