/ (Division) operator

Mit der Spatial Analyst-Lizenz verfügbar.

Mit der Image Analyst-Lizenz verfügbar.

Zusammenfassung

Divides the values of two rasters on a cell-by-cell basis.

Abbildung

Divide operator illustration
OutRas = Raster("InRas1") / Raster("InRas2")

Diskussion

Bei Verwendung eines Operators mit einem Eingabe-Raster ist das Ergebnis ein Raster. Wenn jedoch alle Eingaben Zahlen sind, dann ist das Ergebnis ebenfalls eine Zahl.

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 finden Sie in der Tabelle zur Operator-Priorität unter Arbeiten mit Operatoren in Map Algebra. Sie können die Reihenfolge der Ausführung jedoch mithilfe von Klammern steuern.

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

When a number is divided by zero, the output result is NoData.

The exact division technique used by this operator depends on the application being used when performing it.

In ArcGIS Pro, the floating-point division of Python 3 is always used for this operator, and the output will always be a floating-point value. For example, if 3 is divided by 2, the output is 1.5.

In ArcMap, the divide operator employs the integer division technique of Python 2, where only the integer quotient is retained. If both inputs are integers, the operator performs an integer division, and the output will be an integer. For example, if 3 is divided by 2, the output is 1, or if -3 is divided by 2, the output is -2. If either input is of floating-point type, the divide operator performs a floating-point division, and the output will be a floating-point value. For example, if 3 is divided by 2.0, the output is 1.5.

Hinweis:

Keep this difference in mind if you are migrating from ArcGIS Desktop to ArcGIS Pro, or you will be working in a mixed environment of both. You can use the // (Integer Division) operator if it is important to maintain the integer output.

Another way to perform the divide 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, führt der Operator den Vorgang für jedes Band aus einer Eingabe durch, und die Ausgabe ist ein Multiband-Raster. Die Anzahl an Bändern in jeder Multiband-Eingabe muss identisch sein.

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. Die Ausgabe ist in diesem Fall ein Multiband-Raster.

Wenn beide Eingaben multidimensionale Raster mit derselben Anzahl an Variablen sind, führt der Operator den Vorgang für alle Ausschnitte mit demselben Dimensionswert durch, und die Ausgabe ist ein multidimensionales Raster. Die Variablen in den Eingaben müssen gleiche Dimensionen oder eine gemeinsame Dimension, dürfen jedoch keine nicht gemeinsamen Dimensionen aufweisen.

Wenn beide Eingaben eine Variable, aber unterschiedliche Namen aufweisen, legen Sie für die matchMultidimensionalVariable-Geoverarbeitungsumgebung False fest, um den Vorgang auszuführen.

Wenn eine der Eingaben ein multidimensionales Raster und die andere Eingabe eine Konstante ist, führt der Operator den Vorgang für alle Ausschnitte sämtlicher Variablen mit dem konstanten Wert durch, und die Ausgabe ist ein multidimensionales Raster.

Parameter

OperandErläuterungDatentyp
in_raster_or_constant1

The input whose values will be divided by the second input.

If the first input is a raster and the second is a scalar, an output raster is created with each input raster value being divided by the scalar value.

Raster Layer | Constant
in_raster_or_constant2

The input whose values the first input are to be divided by.

If the first input is a scalar and the second is a raster, an output raster is created, with each input raster value being divided into the scalar value.

Raster Layer | Constant

Codebeispiel

/ (Division) example 1 (Python window)

This sample divides the values of the first input raster by the second.

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outDivide = Raster("degs") / Raster("negs")
outDivide.save("C:/sapyexamples/output/outdivide")
/ (Division) example 2 (stand-alone script)

This sample divides the values of the first input raster by the second.

# Name: Op_Divide_Ex_02.py
# Description: Divides the values of two rasters on a cell-by-cell basis
# 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
inRaster01 = Raster("elevation")
inRaster02 = Raster("landuse")

# Execute Divide
outDivide = inRaster01 / inRaster02

# Save the output 
outDivide.save("C:/sapyexamples/output/outdivide2")

Verwandte Themen