% (模)

摘要

逐个像元地求出第一个栅格数据除以第二个栅格数据的余数(模)。

插图

Modulo illustration
OutRas = Raster("InRas1") % Raster("InRas2")

讨论

使用具有栅格输入的运算符时,结果将为栅格。但是,如果所有输入为数字,那么结果也是数字。

当表达式中使用多个运算符时,其不一定按照从左到右的顺序执行。具有最高优先值的运算符将首先执行。有关运算符优先级的详细信息,请参阅运算符优先级表。您可使用括号来控制执行顺序。

此运算符的运算结果与输入的顺序有关。

任何值对 0 求模(除以)后的输出结果均为 NoData;因此,第二个输入为 0 或 NoData 的任何位置对应在输出中都将返回 NoData。

求模运算符假设它的两个输入都是整数。如果有任何输入不是整数,则将通过截断将这些输入转换为整数。输出值始终是整数。

执行求模运算符的另一种方法为 a %= b,其为 a = a % b 的另一种写法。

语法

in_raster_or_constant1 % in_raster_or_constant2
操作数说明数据类型
in_raster_or_constant1

分子输入。

如果第一个输入为栅格,第二个输入为标量,则将各输入栅格值除以标量值后,计算所得的余数,从而创建输出栅格。

Raster Layer | Constant
in_raster_or_constant2

分母输入。

如果第一个输入为标量,第二个输入为栅格,则将标量值除以各输入栅格值后,计算所得的余数,从而创建输出栅格。

Raster Layer | Constant

返回值

名称说明数据类型
out_raster

输出栅格对象。

像元值为第一个输入的值除以第二个输入的值的余数。

Raster

代码示例

%(模)示例 1(Python 窗口)

此示例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。

import arcpy
from arcpy import env
from arcpy.sa import *
env.workspace = "C:/sapyexamples/data"
outMod = Raster("degs") % Raster("negs")
outMod.save("C:/sapyexamples/output/outmod.tif")
%(模)示例 2(独立脚本)

此示例返回第一个栅格的像元除以第二个栅格的像元的余数(模)值。

# Name: Op_Mod_Ex_02.py
# Description: Finds the remainder of the first raster when divided by
#              the second raster 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
inRaster1 = Raster("degs")
inRaster2 = Raster("negs")

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

# Execute Mod
outMod = inRaster1 % inRaster2

# Save the output 
outMod.save("C:/sapyexamples/output/outmod")

环境

相关主题


7/10/2012