^ (Boolean XOr) operator

Mit der Spatial Analyst-Lizenz verfügbar.

Mit der Image Analyst-Lizenz verfügbar.

Zusammenfassung

Performs a Boolean Exclusive Or operation on the cell values of two input rasters.

Abbildung

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

Auswertung

The ^ operator will perform a Boolean XOr operation when one or more input (operand) is a raster. If both inputs (operands) are numbers, then the ^ operator will perform a Bitwise XOr operation. For more information on how to work with operators, see Working with operators.

Wenn in einem Ausdruck mehrere Operatoren verwendet werden, werden sie nicht zwingend von links nach rechts ausgeführt. Vielmehr wird der Operator mit dem höchsten Vorrangswert zuerst ausgeführt. Weitere Informationen zur Operatorrangfolge finden Sie in der Operatorrangfolgentabelle. Sie können die Reihenfolge der Ausführung jedoch mithilfe von Klammern steuern.

Boolesche Operatoren (~, &, ^, |) haben eine höhere Vorrangstufe als relationale Operatoren (<, <=, >, >=, ==, !=). Daher werden boolesche Operatoren zuerst ausgeführt, wenn sie im gleichen Ausdruck wie relationale Operatoren verwendet werden. Verwenden Sie Klammern, um die Reihenfolge der Ausführung zu ändern.

Wenn mehrere relationale und/oder boolesche Operatoren hintereinander in einem einzelnen Ausdruck verwendet werden, kann die Ausführung in Einzelfällen fehlschlagen. Um dieses potenzielle Problem zu vermeiden, verwenden Sie in dem Ausdruck geeignete Klammern, damit die Reihenfolge für die Ausführung der Operatoren explizit definiert ist. Weitere Informationen finden Sie unter Regeln für komplexe Anweisungen.

Zwei Eingaben sind notwendig, damit die boolesche Auswertung stattfindet.

Für diesen Operator ist die Reihenfolge der Eingabe irrelevant.

Wenn die Eingabewerte Gleitkommazahlen sind, werden sie durch Kürzung in einen Ganzzahlwert konvertiert, bevor der boolesche Vorgang ausgeführt wird. Die Ausgabewerte sind immer ganzzahlig.

Another way to perform the Boolean XOr operation is a ^= b, which is an alternative way to write a = a ^ b.

Wenn beide Eingaben Einzelband-Raster sind oder wenn eine der Eingaben eine Konstante ist, dann ist die Ausgabe ein Einzelband-Raster.

Wenn beide Eingaben Multiband-Raster sind oder wenn eine der Eingaben eine Konstante ist, dann ist die Ausgabe ein Multiband-Raster. Die Anzahl an Bändern in jeder Multiband-Eingabe muss identisch sein.

Der Operator führt den Vorgang für jedes Band aus einer Eingabe mit dem entsprechenden Band aus der anderen Eingabe durch. Wenn eine der Eingaben ein Multiband-Raster und die andere Eingabe eine Konstante ist, führt der Operator den Vorgang für jedes Band in der Multiband-Eingabe mit dem konstanten Wert durch.

Syntax

in_raster_or_constant1 ^ in_raster_or_constant2
OperandErklärungDatentyp
in_raster_or_constant1

The first input to use in the Boolean XOr operation.

Wenn eine der Eingaben ein Raster und die andere ein Skalarwert ist, wird ein Ausgabe-Raster erstellt, wobei die Auswertung für jede Zelle im Eingabe-Raster durchgeführt wird.

Raster Layer | Constant
in_raster_or_constant2

The second input to use in the Boolean XOr operation.

Wenn eine der Eingaben ein Raster und die andere ein Skalarwert ist, wird ein Ausgabe-Raster erstellt, wobei die Auswertung für jede Zelle im Eingabe-Raster durchgeführt wird.

Raster Layer | Constant

Rückgabewert

NameErklärungDatentyp
out_raster

Das Ausgabe-Raster-Objekt.

Die Ausgabewerte sind entweder 0 oder 1.

Raster

Codebeispiel

^ (Boolean XOr) example 1 (Python window)

This sample performs a Boolean XOr operation on two input rasters.

import arcpy
from arcpy import env
from arcpy.ia import *
env.workspace = "C:/iapyexamples/data"
outBooleanXOr = Raster("degs") ^ Raster("negs")
outBooleanXOr.save("C:/iapyexamples/output/outboolxor.tif")
^ (Boolean XOr) example 2 (stand-alone script)

This sample performs a Boolean XOr operation on two input rasters.

# Name: Op_BooleanXOr_Ex_02.py
# Description: Performs a Boolean Exclusive Or operation on the
#              cell values of two input rasters
# Requirements: Image Analyst Extension

# Import system modules
import arcpy
from arcpy import env
from arcpy.ia import *

# Set environment settings
env.workspace = "C:/iapyexamples/data"

# Set local variables
inRaster1 = Raster("degs")
inRaster2 = Raster("negs")

# Execute BooleanXOr
outBooleanXOr = inRaster1 ^ inRaster2

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

Verwandte Themen