^ (Boolean XOr) (arcpy.sa)
Zusammenfassung
Performs a Boolean Exclusive Or operation on the cell values of two input rasters.
Bild
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
Operand | Erläuterung | Datentyp |
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
Name | Erläuterung | Datentyp |
out_raster |
Das Ausgabe-Raster-Objekt. Die Ausgabewerte sind entweder 0 oder 1. | Raster |
Codebeispiel
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")
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")