^ (Boolean XOr) (arcpy.sa)

Zusammenfassung

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

Bild

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

Diskussion

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 zu Operatorrangfolge finden Sie unter +++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 die booleschen Operatoren zuerst ausgeführt, wenn boolesche Operatoren 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.

Syntax

in_raster_or_constant1 ^ in_raster_or_constant2
OperandErläuterungDatentyp
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

NameErläuterungDatentyp
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.sa import *
env.workspace = "C:/sapyexamples/data"
outBooleanXOr = Raster("degs") ^ Raster("negs")
outBooleanXOr.save("C:/sapyexamples/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: 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")

Umgebung

Verwandte Themen

9/12/2013